使用shell脚本实现自动备份MySQL数据库

目的:

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 u s e r − p user -p userppass -h KaTeX parse error: Expected 'EOF', got '#' at position 33: …1" #̲备份目标库 data2="te…data1-KaTeX parse error: Expected 'EOF', got '#' at position 24: … #̲定义备份后的名字 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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值