Linux使用定时任务定时备份mysql数据并压缩备份文件

今天药忘吃喽~ 2023-10-04 13:19 82阅读 0赞

1.检查mysql备份命令有没有作用

在var目录下创建backup目录,在backup目录下创建mysql目录用于存放mysql备份文件

cd到/var/backup目录下

  1. mysqldump -uroot -proot zhaochao> mysql/zhaochao.sql

如果成功,在/var/backup/mysql下会生成zhaochao.sql备份文件

Center

2.创建备份脚本

在/var/backup下创建文件 msyql-backup.sh,文件内容如下所示,保存文件。注意:mysqldump要使用绝对路径,否则会导致备份的文件没有内容,大小为0的情况。

  1. JIRA_FILE_NAME=zhaochao_`date +%Y%m%d%H%M%S`;
  2. cd /var/backup/mysql/
  3. /usr/local/mysql/bin/mysqldump -uroot -pwh5268925 zhaochao > ${JIRA_FILE_NAME}.sql
  4. tar -zcvf ${JIRA_FILE_NAME}.sql.tar.gz ${JIRA_FILE_NAME}.sql
  5. rm -rf ${JIRA_FILE_NAME}.sql

脚本解释:

a.定义生成的备份文件名,用数据库+年月日时分秒的格式定义生成的备份文件名;

b.进入到备份目录,生成的备份文件都将存储在这个路径下;

c.在备份命令中直接输入数据库账号和密码会导致如下警告:

mysqldump: [Warning] Using a password on the command line interface can be insecure

解决办法是在mysql配置文件client部分添加账号密码,然后备份命令中使用该参数–defaults-extra-file=/etc/my.cnf代替 -u和-p参数

d.压缩sql文件,压缩后的文件大小大大缩小,可节省空间

e.删除原备份文件。

3.执行脚本,检测脚本是否能正确执行

cd 到/var/backup目录下 运行./mysql-backup.sh脚本,若正确,则/var/backup/mysql目录下会生成用时间命名并压缩好的备份文件

Center 1

Center 2

4.设置定时器,定时执行mysql-backup.sh脚本

在/var/backup下创建 crontest.cron 文件 内容如下

每隔15分钟执行一次脚本

  1. 15,30,45,59 * * * * /var/backup/mysql-backup.sh

每天早上3点执行

  1. 0 3 * * * /var/backup/mysql-backup.sh

5.将定时文件加到到定时器中,注意,如果修改了crontest.cron的内容,需要重新执行下这个命令,否则定时任务不会跟着更新。

  1. crontab crontest.cron

#

6.检测定时任务有没有加入系统中 crontab -l

  1. [root@iZ23l2efmpqZ backup]# crontab -l
  2. 15,30,45,59 * * * * /var/backup/mysql-backup.sh
  3. 7.取消定时任务 crontab -r
  4. [root@iZ23l2efmpqZ backup]# crontab -l
  5. 15,30,45,59 * * * * /var/backup/mysql-backup.sh
  6. [root@iZ23l2efmpqZ backup]# crontab -r
  7. [root@iZ23l2efmpqZ backup]# crontab -l
  8. no crontab for root

8.拓展:crontab命令用法

基本格式 :
*  *  *  *  *  command
分 时 日 月 周 命令

第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令

crontab文件的一些例子:

30 21 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每晚的21:30重启apache。

45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每月1、10、22日的4 : 45重启apache。

10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每周六、周日的1 : 10重启apache。

0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启apache。

0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每星期六的11 : 00 pm重启apache。

* */1 * * * /usr/local/etc/rc.d/lighttpd restart
每一小时重启apache

* 23-7/1 * * * /usr/local/etc/rc.d/lighttpd restart
晚上11点到早上7点之间,每隔一小时重启apache

0 11 4 * mon-wed /usr/local/etc/rc.d/lighttpd restart
每月的4号与每周一到周三的11点重启apache

0 4 1 jan * /usr/local/etc/rc.d/lighttpd restart
一月一号的4点重启apache

名称 : crontab

使用权限 : 所有使用者

使用方式 :

crontab file [-u user]-用指定的文件替代目前的crontab。

crontab-[-u user]-用标准输入替代目前的crontab.

crontab-1[user]-列出用户目前的crontab.

crontab-e[user]-编辑用户目前的crontab.

crontab-d[user]-删除用户目前的crontab.

crontab-c dir- 指定crontab的目录。

crontab文件的格式:M H D m d cmd.

M: 分钟(0-59)。

H:小时(0-23)。

D:天(1-31)。

m: 月(1-12)。

d: 一星期内的天(0~6,0为星期天)。

cmd要运行的程序,程序被送入sh执行,这个shell只有USER,HOME,SHELL这三个环境变量

说明 :

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

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

定自己的时程表。

参数 :

crontab -e : 执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请先设定 VISUAL 环境变数

来指定使用那个文字编辑器(比如说 setenv VISUAL joe)

crontab -r : 删除目前的时程表

crontab -l : 列出目前的时程表

crontab file [-u user]-用指定的文件替代目前的crontab。

时程表的格式如下 :

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…个小时要执行,其馀类推

使用者也可以将所有的设定先存放在档案 file 中,用 crontab file 的方式来设定时程表。

例子 :

#每天早上7点执行一次 /bin/ls :

0 7 * * * /bin/ls

在 12 月内, 每天的早上 6 点到 12 点中,每隔3个小时执行一次 /usr/bin/backup :

0 6-12/3 * 12 * /usr/bin/backup

周一到周五每天下午 5:00 寄一封信给 alex@domain.name :

0 17 * * 1-5 mail -s “hi” alex@domain.name < /tmp/maildata

每月每天的午夜 0 点 20 分, 2 点 20 分, 4 点 20 分….执行 echo “haha”

20 0-23/2 * * * echo “haha”

注意 :

当程序在你所指定的时间执行后,系统会寄一封信给你,显示该程序执行的内容,若是你不希望收到这样的信,请在每一行空一格之

后加上 > /dev/null 2>&1 即可

例子2 :

#每天早上6点10分

10 6 * * * date

#每两个小时

0 */2 * * * date

#晚上11点到早上8点之间每两个小时,早上8点

0 23-7/2,8 * * * date

#每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

0 11 4 * mon-wed date

#1月份日早上4点

0 4 1 jan * date

范例

$crontab -l 列出用户目前的crontab.

发表评论

表情:
评论列表 (有 0 条评论,82人围观)

还没有评论,来说两句吧...

相关阅读

    相关 MySql定时备份数据

    通过定时执行Linux命令crontab实现数据库自动定时备份功能。 前提:查看系统是否已安装crontab命令 查看方面命令行输入crontab 如果提示command