2021-11-05 Mysql远程同步数据库的脚本(expect)

cat mysql-dump.sh

#!/usr/bin/expect -f
# 变量定义
set HOST "192.168.26.42"
set USERNAME ipms
set PASSWORD ipms
set DB ipms
set DIR "/home/ipms/bs/bin"
set FILE $DB.bak
set DB_USER root
set DB_PASS root

# 传输文件,直到传输完成
spawn mysqldump -u$DB_USER -p$DB_PASS --databases $DB > $DIR/$FILE
spawn scp -P 22 $DIR/$FILE $USERNAME@$HOST:$DIR/$FILE
expect {
    "password" {set timeout -1; send "$PASSWORD\n"; exp_continue;}
    "(yes/no)?" {send "yes\n";}
}

# SSH登录
spawn ssh $USERNAME@$HOST
expect {
    "password" {send "$PASSWORD\n"}
    "(yes/no)?" {send "yes\n";}
}

# 恢复数据库
expect "$USERNAME@*"  {send "mysql -u$DB_USER -p$DB_PASS < $DIR/$FILE\n"}

# 退出SSH登录
expect "$USERNAME@*"  {send "exit\n"}

expect eof

根据实际测试情况

  1. 如果远程已有该数据库,则会被覆盖。
  2. 如果远程无该数据库,则会被增加
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值