首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用shell脚本实现自动备份MySQL数据库

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

作者头像
小手冰凉
发布2019-09-10 10:40:02
2K0
发布2019-09-10 10:40:02
举报
文章被收录于专栏:小手冰凉小手冰凉

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
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-08-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
访问管理
访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档