mysql全量本地或异地备份脚本

1、安装expect

yum -y install expect

2、创建备份脚本 vi /data/backup.sh

#!/bin/bash
#adonis 聆听雨

#备份文件名时间
bkdate=$(date +%Y%m%d%H%M%S)

#备份的文件名;例如: databak20210918101654
bakFileName=databak$bkdate

#要备份的数据库root密码
mysql_password='lsgz3edc#EDC'

#要备份的数据库实例端口
mysql_port=3306

#本机备份存放目录
backupdir=/data/backup

#删除本机15天以前的备份
day=15

#备份至目标主机IP地址
dst_host=59.213.129.163

#备份至目标主机ssh密码
dst_sshPassword='lsgz3edc#EDC'

#备份至目标主机ssh端口
dst_sshPort=52225

if [ ! -d $backupdir ]; then

        mkdir -p $backupdir
fi

find $backupdir -type f -mtime +$day -exec rm -rf {} \; > /dev/null 2>&1

/data/mysql/bin/mysqldump --defaults-file=/etc/my.cnf  -uroot -p$mysql_password -P$mysql_port --all-databases --lock-all-tables  --routines --triggers --events --flush-logs --set-gtid-purged=OFF  | gzip > ${backupdir}/$bakFileName.sql.gz

cd $backupdir

/usr/bin/expect <<-EOF

spawn scp -P $dst_sshPort  -r ${backupdir}/$bakFileName.sql.gz root@$dst_host:/data/mysql_backup

set timeout 300

expect {
"(yes/no)?" {
   send "yes\n"
   expect "*assword:" { send "$dst_sshPassword\r"}
  }
  "*assword:" {
   send "$dst_sshPassword\n"
  }
}

expect eof

EOF

设置可执行权限

chmod +x /data/backup.sh

3、添加定时任务,每天晚上凌晨1点执行

0 1 * * * /data/backup.sh

下方为本地全量备份脚本,chmox +x /opt/databakfull.sh设置脚本执行权限,然后添加到定时任务里面即可。

[root@mysql-hist opt]# cat databakfull.sh
#!/bin/bash
rq1=$(date +%Y%m%d)

#判断备份目录是否存在,不存在则自动创建
if [ ! -d /data/backup ];then
   mkdir -p /data/backup
fi

#mysql备份命令
mysqldump  -uroot -pAdmin123@qwe --all-databases --lock-all-tables --routines --triggers --events --flush-logs --set-gtid-purged=OFF| gzip > /data/backup/db$rq1.sql.gz

#删除超过3天的备份文件
find /data/backup/data* -name "*.*" -mtime +3 -type f -exec rm {} \;
声明: 本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

给TA打赏
共{{data.count}}人
人已打赏
Mysql

mysql创建数据库 utf-8/mb4

2024-1-15 14:32:53

Mysql

mysql8.0预编译二进制安装教程

2024-1-23 11:31:19

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索