mysqldump免密码导出方法

新出的mysql由于安全性的问题,在命令行中填入密码,会提示该操作不安全,但最绝的是它会自动终止你的命令。
所以,没办法,想了用自动应答的expect功能,大致输入以下内容

#!/usr/bin/expect
spawn mysql -uroot -p
expect "Enter password:"
send "xxxxx\r"
interact

spawn:必需,是expect的语句,执行命令前都要加这句,意义是启动新的进程
expect:从进程接收字符串,但这里可以不需要,因为返回的字符串不变。
send:用于向进程发送字符串
interact:允许用户交互,无这句运行完会直接退出,有这个会进入到进程下一步骤

保存后,增加运行权限给该x.sh,chmod +x ./x.sh
运行后可以进入到mysql命令行,但使用mysqldump命令好像无法导出数据。

后来,发现可以通过新建.my.cnf的方式进行免密码导出。而且,该方式能锁定只有当前用户有这种权限,其他用户无效。
1、在用户的根目录下
cd ~
2、新建.my.cnf文件,内容如下

[mysqldump]
user=xxxxx
password=xxxxx

保存,即可,也不需重启mysql。

你可能感兴趣的:(服务器,mysql)