?
在自己的博客网站,使用的是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
2、安装crontab
说明:
crontab 是用来让使用者在固定时间或固定间隔执行程序之用,换句话说,也就是类似使用者的时程表。
-u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。
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...个小时要执行,其馀类推
部分例子:
4、我的执行和排错过程:
按照教程,我都设置好了,为了测试,我一分钟跑一次数据库备份,结果机器爆了,cpu和内存。所以我不停的在kill进程和stop定时器。
日志:/var/log/cron
下面是我的一些执行结果:
设置了3点15分运行定时器:
我修改了sh文件和改变了定时器的时间,设置为3:15,可以看到,在3:15是执行了我的脚本的。
最后,可以看到,数据库备份是创建成功了
?