Linux下MySQL备份以及crontab定时备份(crontab表达式简介)

68 篇文章 3 订阅

1. 备份某个数据库

[plain]  view plain  copy
  1. ##################################################################  
  2. # 备份某个数据库  
  3. ##################################################################  
  4.   
  5. # root 用户,创建备份目录  
  6. mkdir -p /usr/local/cncounter/mysql_dump  
  7. cd /usr/local/cncounter/mysql_dump  
  8.   
  9. # 导出数据库,热备  
  10. mysqldump -u root -pmypasssecret cncounter > cncounter_dump.sql.20140414_1333  

2. 还原某个数据库

[plain]  view plain  copy
  1. ##################################################################  
  2. # 还原某个数据库  
  3. ##################################################################  
  4. # 修改密码  
  5. # mysqladmin -u root password "mypasssecret"  
  6. # mysqladmin -u root password oldpass "mypasssecret"  
  7.   
  8. # 登录  
  9. mysql -u root -pmypasssecret  
  10.   
  11. -- 热备只是备份数据库内部的表,以及数据  
  12. use cncounter;  
  13. source /usr/local/cncounter/mysql_dump/cncounter_dump.sql.20140414_1333;  
  14. exit;  
3. crontab 定时备份

3.1 编辑备份脚本

[plain]  view plain  copy
  1. ##################################################################  
  2. # crontab 定时备份  
  3. ##################################################################  
  4. #   
  5. # root 用户,创建执行脚本  
  6. mkdir -p /root/mysql_dump/data  
  7. cd /root/mysql_dump  
  8. touch mysql_back.sh  
  9. chmod 755 mysql_back.sh  
  10.   
  11. # 编辑备份脚本  
  12. vim mysql_back.sh  
  13.   
  14. ################下面是备份脚本的内容  
  15. #!/bin/sh  
  16. # File: /root/mysql_dump/mysql_back.sh  
  17. # Database info  
  18. DB_NAME="cncounter"  
  19. DB_USER="root"  
  20. DB_PASS="mypasssecret"  
  21. # Others vars  
  22. # whereis mysqldump  
  23. # IS ` but not '  
  24. BIN_DIR="/usr/bin"  
  25. BCK_DIR="/root/mysql_dump/data"  
  26. DATE=`date +%Y%m%d_%H%M%S`  
  27. # TODO  
  28. mkdir -p $BCK_DIR  
  29. $BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS $DB_NAME \  
  30.  > $BCK_DIR/$DB_NAME.dump_$DATE.sql  

当然,执行的脚本也可以不用那么灵活: 其中行末尾的 反斜线(\) 的意思是shell 指令换行,如果写在单行内部,就不再需要.

[plain]  view plain  copy
  1. /usr/bin/mysqldump --opt -uroot -pmypasssecret cncounter \  
  2. > /root/mysql_dump/data/cncounter.dump_`date +%Y%m%d_%H%M%S`.sql  

dump出来的sql文件有可能很大,我们也可以开启 gzip 压缩,一般来说可以实现10倍压缩比例:也就是讲输出到文件的内容通过管道操作符让 gzip 程序处理一遍.

[plain]  view plain  copy
  1. /usr/bin/mysqldump --opt -uroot -pmypasssecret cncounter | gzip \  
  2. > /root/mysql_dump/data/cncounter.dump_`date +%Y%m%d_%H%M%S`.sql.gz  


3.2 添加到crontab

[plain]  view plain  copy
  1. # 添加到crontab  
  2. crontab -e  
  3.   
  4. # 添加一行,root用户不需要指定执行的用户名,ESC,wq  
  5. 1 1 * * * /root/mysql_dump/mysql_back.sh  
  6.   
  7. # 不一定需要重启crontab服务  
  8. # service crond restart  
3.3 crontab 简单说明

[plain]  view plain  copy
  1. # cat /etc/crontab   
  2. SHELL=/bin/bash  
  3. PATH=/sbin:/bin:/usr/sbin:/usr/bin  
  4. MAILTO=root  
  5. HOME=/  
  6.   
  7. # For details see man 4 crontabs  
  8.   
  9. # Example of job definition:  
  10. # .---------------- minute (0 - 59)  
  11. # |  .------------- hour (0 - 23)  
  12. # |  |  .---------- day of month (1 - 31)  
  13. # |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...  
  14. # |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat  
  15. # |  |  |  |  |  
  16. # *  *  *  *  * user-name command to be executed  
可以发现,crontab 的执行周期有5个部分组成,其中第一个是分钟数,第二个是小时数,第三个是一个月中的第几天。。。 如果是 * 就表示每天都会调度。

user-name 部分,如果需要以其他用户调度,则可以指定,否则不能指定,比如 root 用户就不能指定 root,否则有调度日志,但是没有实际执行。




ps :新建的文件夹和 sh脚本文件记得赋权限777 



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。 
0 */1 * * * /usr/local/etc/rc.d/lighttpd restart 
每一小时重启apache 
0 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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值