linux环境下的mysql定时备份

?

 在自己的博客网站,使用的是Nacos作为配置和注册中心,又和数据库进行关联的,由于数据,数据和网站设置都存储在数据库当中,所以一直想着要做一个备份。所以找了一个比较简单的定时备份模式。当然,是基于linux下的。

 

方式:采用linux系统中的定时器,定时执行shell脚本,进行数据库的库导出。

在此需要注意的是:新创建的 cron 任务,不会马上执行,至少要过 2 分钟后才可以,当然你可以重启 cron 来马上执行。

首先创建一个自己的shell脚本,用于数据库的导出,我用的也是别人写好的

原作者链接:蘑菇博客:http://www.moguit.cn

 

1、设置一个目录bak,作为备份文件的存放点,导出对应数据库的数据

        其中 -uroot -p‘admin‘  等同于 -u root -p admin   即用户名和密码

        如果mysqldump没有在/usr/local/bin当中的话,会出现command not found 

        此时有两种选择: 1是建立一个软链接,由实际路径指向bin下面的同名文件,2是写mysqldump的全路径。

以下是备份数据库的脚本:提供者:蘑菇博客:http://www.moguit.cn

#!/bin/sh

bseDir="/bak";

cd "$baseDir";

echo "开始备份数据库";

#开始备份mogu_blog数据库

echo `mysqldump  -uroot -p‘admin‘ --default-character-set=utf8  mogu_blog > mogu_blog_$(date +%Y%m%d).sql`;

#开始备份mogu_picture数据库

echo `mysqldump  -uroot -p‘w1313375‘ --default-character-set=utf8  mogu_picture > mogu_picture_$(date +%Y%m%d).sql`;

echo "正在进行备份文件打包"

echo `tar zcvf mogu_blog_$(date +%Y%m%d).tar.gz  mogu_blog_$(date +%Y%m%d).sql mogu_picture_$(date +%Y%m%d).sql `;

echo `rm -rf mogu_blog_$(date +%Y%m%d).sql`;

echo `rm -rf mogu_picture_$(date +%Y%m%d).sql`;

echo "备份数据完成";

oldDate=`date --date=‘8 day ago‘ +%Y%m%d`;

#删除当前日期-8的备份

echo `rm -rf mogu_blog_$oldDate*`;

echo "删除$oldDate的备份成功"
linux环境下的mysql定时备份

2、安装crontab

说明:

        crontab 是用来让使用者在固定时间或固定间隔执行程序之用,换句话说,也就是类似使用者的时程表。

        -u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。

1、首先先安装crond

yum install crontabs

2、crond启动命令

systemctl start crond

3、关闭

systemctl stop crond

4、开启自启

systemctl enable crond

5、查看时间任务

crontab -l

6、设置任务

crontab -e    (生成的任务在/var/spool/cron/下,文件名为登录的用户名)
linux环境下的mysql定时备份

 

3、主要在设置任务的时候,需要指定时间。

      值得注意的是:在指定crond任务的时候,如 sh startup.sh 由于crond不会引入变量,所以要么自己引入,要么写全路径 改写成 /bin/sh startup.sh 否则定时器执行了,但是没有任何效果。

定时器时间格式为: f1 f2 f3 f4 f5 program
  • 其中 f1 是表示分钟,f2 表示小时,f3 表示一个月份中的第几日,f4 表示月份,f5 表示一个星期中的第几天。program 表示要执行的程序。
  • 当 f1 为 * 时表示每分钟都要执行 program,f2 为 * 时表示每小时都要执行程序,其馀类推
  • 当 f1 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第 b 小时都要执行,其馀类推
  • 当 f1 为 */n 时表示每 n 分钟个时间间隔执行一次,f2 为 */n 表示每 n 小时个时间间隔执行一次,其馀类推
  • 当 f1 为 a, b, c,... 时表示第 a, b, c,... 分钟要执行,f2 为 a, b, c,... 时表示第 a, b, c...个小时要执行,其馀类推
*    *    *    *    *
-    -    -    -    -
|    |    |    |    |
|    |    |    |    +----- 星期中星期几 (0 - 7) (星期天 为0)
|    |    |    +---------- 月份 (1 - 12) 
|    |    +--------------- 一个月中的第几天 (1 - 31)
|    +-------------------- 小时 (0 - 23)
linux环境下的mysql定时备份

部分例子:

0 */2 * * * /sbin/service httpd restart  意思是每两个小时重启一次apache 

50 7 * * * /sbin/service sshd start  意思是每天7:50开启ssh服务 

50 22 * * * /sbin/service sshd stop  意思是每天22:50关闭ssh服务 

0 0 1,15 * * fsck /home  每月1号和15号检查/home 磁盘 

1 * * * * /home/bruce/backup  每小时的第一分执行 /home/bruce/backup这个文件 

00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} \;  每周一至周五3点钟,在目录/home中,查找文件名为*.xxx的文件,并删除4天前的文件。

30 6 */10 * * ls  意思是每月的1、11、21、31日是的6:30执行一次ls命令
linux环境下的mysql定时备份

 

4、我的执行和排错过程:

      按照教程,我都设置好了,为了测试,我一分钟跑一次数据库备份,结果机器爆了,cpu和内存。所以我不停的在kill进程和stop定时器。

      日志:/var/log/cron

      下面是我的一些执行结果:

      设置了3点15分运行定时器:

linux环境下的mysql定时备份?

linux环境下的mysql定时备份

      我修改了sh文件和改变了定时器的时间,设置为3:15,可以看到,在3:15是执行了我的脚本的。

linux环境下的mysql定时备份?

linux环境下的mysql定时备份

      最后,可以看到,数据库备份是创建成功了

linux环境下的mysql定时备份?

linux环境下的mysql定时备份

 

 


?

linux环境下的mysql定时备份

上一篇:AcWing 3485. 最大异或和 异或字典树的删除


下一篇:IDEA下:SpringBoot报错 Error running 'Application': Command line is too long. Shorten command line for Application or also for Spring Boot default configuration?