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

[[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

原文地址:https://blog.51cto.com/14227204/2428499

时间: 2024-10-28 22:14:03

使用shell脚本实现自动备份MySQL数据库的相关文章

shell学习之自动备份mysql数据库

首先登陆mysql: mysql -u root -p 注意:不是系统root的密码,mysql安装好后默认root密码为空 >set password for 'root'@'localhost' = password('*****'); --修改root用户的本地密码 >grant all on zabbix.* to [email protected]'localhost' identified by "123456"; ---创建备份zabbix数据库的用户和密码,

Shell脚本-----自动备份Mysql数据库

脚本的整体思路 1.定义需要的变量 2.利用for循环备份需要备份的库,并以库名-当天日期.sql命名,并记录相关日志 3.建立备份当天的日期的目录,向备份的Sql文件移动到该目录 4.压缩打包该目录,以节省空间,打包成功后删除该目录 5.备份目录只备份七天的数据库,第八天删除第一天的备份,目录只会存在连续七天的备份文件 6.查找备份目录下的.log日志文件,超过七天的删除 #!/bin/bash mysql_bin=/usr/local/tdoa/mysql/bin/mysqldump use

SHELL 自动备份MYSQL数据库(备份单个数据库及所有数据库)

SHELL 自动备份MYSQL数据库 备份单个数据库及所有数据库 楓城浪子原创,转载请标明出处! 更多技术博文请见个人博客:https://fengchenglangzi.000webhostapp.com 微信bh19890922 QQ445718526.490425557 部分截图: 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657

如何在生产环境下实现每天自动备份mysql数据库

1.描述 我相信很多朋友在工作都都会有这种需求,老板或领导让你每天都要备份mysql数据库,你该如何实现呢,是每天到一定的时间在服务器上敲一遍mysql的备份命令,还是想写个脚本,定时定点的自动备份呢?我相信大家都想让它自动备份,接下来我通"shell脚本+定时任务"的方式来实现自动备份mysql数据库. 2.环境 备份路径:/data/mysqlbak/ 备份脚本:/data/mysqlbak/mysqlbak.sh 备份时间:每天23:59备份 备份要求:比如备份的数据只保留1周

Linux 每天自动备份mysql数据库的方法

Linux 每天自动备份mysql数据库的方法 作者: 字体:[增加 减小] 类型:转载 linux下为了安全有时候需要自动备份mysql数据库,下面是具体的实现步骤. /usr/bin为mysql安装目录 建备份文件夹: mkdir mysql_data_bak 建脚本文件: touch autobackupmysql.sh 打开文件 vi autobackupmysql.sh 在脚本中加入如下内容: filename=`date +%Y%m%d` /usr/bin/mysqldump -op

CentOS下每天自动备份mysql数据库

每天自动备份mysql数据库的脚本,并且自动发送到你指定的邮箱面,这样vpser再也不会为丢失数据烦恼啦. mysqldump -uuser -ppassword –databases db1 db2 db3 > /home/website/backups/databackup.sql tar zcf /home/website/backups/databackup.sql.tar.gz /home/website/backups/ echo "主题:数据库备份" |mutt  

自动备份mysql数据库并发送到Email方法

一个博客,一个网站最重要的就是数据库,所以经常备份数据是必须的.尽管 WordPress 有定时备份数据的插件,但只能备份当前的博客,不够灵活.适合个人小小博客,对于一些网站来说,就不适合了.现在很多人都拥有多个网站,showfom 同学就有几个网站.每个网站都装个插件就比较麻烦了.况且不是每个网站都是 WordPress 的 . 所以写了个自动备份mysql数据库的脚本,再加上gmail这个G级邮箱,备份多少数据都可以了...下面是代码: mysqldump -uuser -ppassword

一个自动备份mysql数据库的bat文件内容

自动备份mysql数据库,并已当前的日期时间为目录 copy过去, xcopy将近15年没有用dos命令,还是这么亲切 另 本方法是备份数据库文件,不是dump导出,然后再计划任务中使用,我用的是wamp,其他的环境类似的改改即可 ====dbback.bat============ NET STOP wampapacheNET STOP wampmysqldset /a t1=(1%time:~0,2%-100)*1if %t1% LSS 10 set t1=0%t1%set ymd_hms=

Shell脚本使用汇总整理——mysql数据库5.7.8以前备份脚本

Shell脚本使用的基本知识点汇总详情见连接: https://www.cnblogs.com/lsy-blogs/p/9223477.html 脚本分为三部分配置信息.脚本文件.定时任务: 1.配置信息: username=rootpassword=123456backupsFileStr=/wocloud/db/backupsbackupsFileDay=3mysqldumpStr=/usr/bin/mysqldumpcopydb=hebei,reportSystem 参数说明: usern