目的:

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服务器上使用该账号进行手工备份,测试是否可以备份成功:

[root@localhost ~]# mysqldump -u operator -p123456 -h 192.168.1.1 --databases test1 > test1.sql

编写shell脚本:

[root@localhost ~]# mkdir -p /opt/backup             #创建备份后的存放目录[root@localhost ~]# 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

测试备份是否成功:

[root@localhost ~]# chmod +x mysqlbak.sh            #赋予该脚本执行权限[root@localhost ~]# ./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.[root@localhost ~]# ls /opt/backup/                   #查看备份后的文件,OK!test1-20190521-2254.tar.gz  test2-20190521-2254.tar.gz

设置计划任务:

[root@localhost ~]# mv mysqlbak.sh /opt/backup/              #将脚本也移至备份目录[root@localhost backup]# crontab -e          #编辑计划任务00      22      *       *       *       /opt/backup/mysqlbak.sh[root@localhost 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

齐活...................

©著作权归作者所有:来自51CTO博客作者mb5c7bb57d7f7e8的原创作品,如需转载,请注明出处,否则将追究法律责任

每一份赞赏源于懂得

赞赏

0人进行了赞赏支持

更多相关文章

  1. Java正则表达式过滤脚本威胁--封装类
  2. 使用shell脚本监控Linux主机
  3. 教你如何在 Linux 中锁定和解锁多个用户
  4. Centos8 中如何缩减 XFS 分区格式的根目录
  5. 数栈数据安全案例:混合云环境数据库备份容灾实现
  6. MFS+Keepalived双机高可用热备方案操作记录
  7. 小麦苗数据库巡检脚本,支持Oracle、MySQL、SQL Server和PG等数据
  8. 保留最新N份备份目录脚本
  9. Oracle OCR的备份与恢复

随机推荐

  1. 策略模式原来就这么简单!
  2. Docker入门为什么可以这么简单?
  3. JAVA中的“抽象接口”
  4. 三分钟学会门面模式!
  5. 海康网络摄像机SDK Linux对接
  6. 2018再见,2019你好
  7. 国外版《从入门到放弃》大全,脑洞无极限!
  8. 使用Python开发鸿蒙应用--2021.01.07直播
  9. SpringBoot自动配置原理!
  10. 2.19 使用vSphere Client端的USB设备详解