使用shell脚本实现自动备份MySQL数据库
发布时间:2020-12-16 01:53:22 所属栏目:安全 来源:网络整理
导读:192.168.1.2服务器对192.168.1.1服务器上的MySQL数据库进行备份。 必须满足的条件: 1、在192.168.1.1服务器上创建专门用来备份的数据库账号,并赋予相应的权限: mysql grant select,lock tables on *.* to ‘operator‘@‘192.168.%.%‘ identified by ‘1
192.168.1.2服务器对192.168.1.1服务器上的MySQL数据库进行备份。
必须满足的条件: 1、在192.168.1.1服务器上创建专门用来备份的数据库账号,并赋予相应的权限: mysql> grant select,lock tables on *.* to ‘operator‘@‘192.168.%.%‘ identified by ‘123456‘; #备份数据库需要账号具有查看表和锁定表的权限 2、在192.168.1.2服务器上使用该账号进行手工备份,测试是否可以备份成功: [[email?protected] ~]# mysqldump -u operator -p123456 -h 192.168.1.1 --databases test1 > test1.sql 编写shell脚本: [[email?protected] ~]# mkdir -p /opt/backup #创建备份后的存放目录 [[email?protected] ~]# vim mysqlbak.sh #编写shell脚本 #!/bin/bash #定义数据库连接、目标信息库等信息: user="operator" #定义用户名账号 pass="123456" #密码 host="192.168.1.1" #目标主机 conn=" -u $user -p$pass -h $host" data1="test1" #备份目标库 data2="test2" bak="/opt/backup" #指定备份目录 cmd="/usr/local/mysql/bin/mysqldump" #指定命令工具 time=`date +%Y%m%d-%H%M` #定义时间变量 name_1="$data1-$time" #定义备份后的名字 name_2="$data2-$time" cd $bak #切换至备份目录下 $cmd $conn --databases $data1 > $name_1.sql #备份为.sql文件 $cmd $conn --databases $data2 > $name_2.sql /bin/tar zcf $name_1.tar.gz $name_1.sql --remove > /dev/null #打包后删除源文件 /bin/tar zcf $name_2.tar.gz $name_2.sql --remove > /dev/null 测试备份是否成功: [[email?protected] ~]# chmod +x mysqlbak.sh #赋予该脚本执行权限 [[email?protected] ~]# ./mysqlbak.sh #执行脚本测试是否备份成功 Warning: Using a password on the command line interface can be insecure. Warning: Using a password on the command line interface can be insecure. [[email?protected] ~]# ls /opt/backup/ #查看备份后的文件,OK! test1-20190521-2254.tar.gz test2-20190521-2254.tar.gz 设置计划任务: [[email?protected] ~]# mv mysqlbak.sh /opt/backup/ #将脚本也移至备份目录 [[email?protected] backup]# crontab -e #编辑计划任务 00 22 * * * /opt/backup/mysqlbak.sh [[email?protected] backup]# systemctl status crond #确保crond服务已运行 ● crond.service - Command Scheduler Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled) Active: active (running) since 二 2019-05-21 22:15:30 CST; 49min ago Main PID: 1493 (crond) Tasks: 1 CGroup: /system.slice/crond.service └─1493 /usr/sbin/crond -n (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |