mysql – 当ssh用于在另一台服务器上转储备份文件时,为什么会出现`tcgetattr`错误?

我想在另一台服务器上转储表备份,我正在使用ssh来完成它.
当我运行以下命令时,它会出错,但转储文件会复制到目标.

mysqldump -u username -ppassword dbname tablename | ssh -t -t servers_username@domain_name 'cat > /tmp/bckp.sql';

tcgetattr: Invalid argument

如果我按下CTRL c,则会附加错误信息,信号为2.

为什么会出错?

最佳答案
当使用ssh -t -t或ssh -tt强制伪终端分配时,我看到了这个错误.

tcgetattr函数用于查找由文件描述符表示的伪终端的属性;它需要一个文件描述符和一个指向termios结构的指针来存储终端元数据.我从stub code in glibc看到这个错误代表了termios结构的空指针.我不确定这些相同的错误处理语义是否适用于tcgetattr的特定于平台的实现.

如果要抑制此错误,请像这样调用ssh:

ssh 2>/dev/null

这会将STDERR重定向到/ dev / null;使用此重定向调用时,您将看不到错误.请注意,这将掩盖ssh的其他错误;您可能需要删除它以进行调试.

相关文章

在正式开始之前,我们先来看下 MySQL 服务器的配置和版本号信...
> [合辑地址:MySQL全面瓦解](https://www.cnblogs.c...
物理服务机的CPU、内存、存储设备、连接数等资源有限,某个时...
1 回顾 上一节我们详细讲解了如何对数据库进行分区操作,包括...
navicat查看某个表的所有字段的详细信息 navicat设计表只能一...
文章浏览阅读4.3k次。转载请把头部出处链接和尾部二维码一起...