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。

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值