使用shell脚本自动备份MySQL数据库的具体操作-创新互联

不知道大家之前对类似使用shell脚本自动备份MySQL数据库的具体操作的文章有无了解,今天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分吧,相信看完使用shell脚本自动备份MySQL数据库的具体操作你一定会有所收获的。

创新互联专注于企业全网营销推广、网站重做改版、梅列网站定制设计、自适应品牌网站建设、HTML5建站商城网站定制开发、集团公司官网建设、外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为梅列等各大城市提供网站开发制作服务。

目的:

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

看完使用shell脚本自动备份MySQL数据库的具体操作这篇文章,大家觉得怎么样?如果想要了解更多相关,可以继续关注我们的行业资讯板块。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享文章:使用shell脚本自动备份MySQL数据库的具体操作-创新互联
文章起源:http://myzitong.com/article/cccioe.html