linux mysql 自动备份

2010年4月24日 | 分类: IT技术 | 标签: ,

目标:
使用cron自动执行mysql备份命令备份mysql数据库

步骤:
1. shell脚本 mysqlbackup.sh

#!/bin/bash
#定义变量,注意等号前后无空格
BACKUP_DIR="/root/mysqlbackup"
DATE=$(/bin/date +%Y%m%d%H%M%S)
FILE_NAME="testdb_$DATE.sql.gz";
 
echo "starting backup database"
 
#使用mysqldump命令备份我的mysql数据库,并通过gzip进行压缩
exec /usr/bin/mysqldump -uroot -proot --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x test_database | gzip > $BACKUP_DIR/$FILE_NAME
 
echo "end backup database"

2. 赋予执行权限

chmod a+x ./mysqlbackup.sh

3. 使用crontab -e命令编辑自己的crontab任务

0 16 * * * /root/mysqlbackup.sh

上面表示每天的16点整自动执行mysqlbackup.sh

相关知识:
1. mysql备份命令

/usr/bin/mysqldump -uMysql账户 -pMysql密码 --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x 数据库名

例如

/usr/bin/mysqldump -uroot -proot --default-character-set=utf8 --opt --extended-insert=false --triggers -R --hex-blob -x test_database

2. 关于date的格式

>> date --help                                                                                           
用法:date [选项]... [+格式]                                                                             
 或:date [-u|--utc|--universal] [MMDDhhmm[[CC]YY][.ss]]                                                 
以给定的格式显示当前时间,或是设置系统日期。                                                             
 
  -d,--date=字符串              显示指定字符串所描述的时间,而非当前时间
  -f,--file=日期文件            类似--date,从日期文件中按行读入时间描述
  -r, --reference=文件          显示文件指定文件的最后修改时间         
  -R, --rfc-2822                以RFC 2822格式输出日期和时间           
                                例如:2006年8月7日,星期一 12:34:56 -0600
      --rfc-3339=TIMESPEC       以RFC 3339 格式输出日期和时间。         
                                TIMESPEC=`date',`seconds',或 `ns'     
                                表示日期和时间的显示精度。               
                                日期和时间单元由单个的空格分开:         
                                2006-08-07 12:34:56-06:00               
  -s, --set=字符串              设置指定字符串来分开时间                 
  -u, --utc, --universal        输出或者设置协调的通用时间               
      --help            显示此帮助信息并退出                             
      --version         显示版本信息并退出                               
 
给定的格式FORMAT 控制着输出,解释序列如下:
 
  %%    一个文字的 %
  %a    当前locale 的星期名缩写(例如: 日,代表星期日)
  %A    当前locale 的星期名全称 (如:星期日)         
  %b    当前locale 的月名缩写 (如:一,代表一月)     
  %B    当前locale 的月名全称 (如:一月)             
  %c    当前locale 的日期和时间 (如:2005年3月3日 星期四 23:05:25)
  %C    世纪;比如 %Y,通常为省略当前年份的后两位数字(例如:20)   
  %d    按月计的日期(例如:01)                                   
  %D    按月计的日期;等于%m/%d/%y                               
  %e    按月计的日期,添加空格,等于%_d                           
  %F    完整日期格式,等价于 %Y-%m-%d                             
  %g    ISO-8601 格式年份的最后两位 (参见%G)                     
  %G    ISO-8601 格式年份 (参见%V),一般只和 %V 结合使用         
  %h    等于%b                                                   
  %H    小时(00-23)                                               
  %I    小时(00-12)                                               
  %c    按年计的日期(001-366)                                     
  %k    时(0-23)                                                 
  %l    时(1-12)                                                 
  %m    月份(01-12)                                               
  %M    分(00-59)                                                 
  %n    换行                                                     
  %N    纳秒(000000000-999999999)                                 
  %p    当前locale 下的"上午"或者"下午",未知时输出为空           
  %P    与%p 类似,但是输出小写字母                               
  %r    当前locale 下的 12 小时时钟时间 (如:11:11:04 下午)       
  %R    24 小时时间的时和分,等价于 %H:%M                         
  %s    自UTC 时间 1970-01-01 00:00:00 以来所经过的秒数           
  %S    秒(00-60)                                                 
  %t    输出制表符 Tab                                           
  %T    时间,等于%H:%M:%S                                       
  %u    星期,1 代表星期一                                       
  %U    一年中的第几周,以周日为每星期第一天(00-53)
  %V    ISO-8601 格式规范下的一年中第几周,以周一为每星期第一天(01-53)
  %w    一星期中的第几日(0-6),0 代表周一
  %W    一年中的第几周,以周一为每星期第一天(00-53)
  %x    当前locale 下的日期描述 (如:12/31/99)
  %X    当前locale 下的时间描述 (如:23:13:48)
  %y    年份最后两位数位 (00-99)
  %Y    年份
  %z +hhmm              数字时区(例如,-0400)
  %:z +hh:mm            数字时区(例如,-04:00)
  %::z +hh:mm:ss        数字时区(例如,-04:00:00)
  %:::z                 数字时区带有必要的精度 (例如,-04,+05:30)
  %Z                    按字母表排序的时区缩写 (例如,EDT)
 
默认情况下,日期的数字区域以0 填充。
以下可选标记可以跟在"%"后:
 
  - (连字符)不填充该域
  _ (下划线)以空格填充
  0 (数字0)以0 填充
  ^ 如果可能,使用大写字母
  # 如果可能,使用相反的大小写
 
在任何标记之后还允许一个可选的域宽度指定,它是一个十进制数字。
作为一个可选的修饰声明,它可以是E,在可能的情况下使用本地环境关联的
表示方式;或者是O,在可能的情况下使用本地环境关联的数字符号。
 
请向bug- coreutils@gnu.org 报告date 的错误
GNU coreutils 项目主页:<http ://www.gnu.org/software/coreutils/>
GNU 软件一般性帮助:<http ://www.gnu.org/gethelp/>
请向<http ://translationproject.org/team/zh_CN.html> 报告date 的翻译错误</http>

3. cron 配置计划任务的书写格式

分钟 小时 日 月 周 [用户名] 命令

说明:

第一段应该定义的是:分钟,表示每个小时的第几分钟来执行。范围是从0-59
第二段应该定义的是:小时,表示从第几个小时来执行,范围是从0-23
第三段应该定义的是:日期,表示从每个月的第几天执行,范围从1-31
第四段应该定义的是:月,表示每年的第几个月来执行,范围从1-12
第五段应该定义的是:周,表示每周的第几天执行,范围从0-6,其中 0表示星期日。
每六段应该定义的是:用户名,也就是执行程序要通过哪个用户来执行,这个一般可以省略;
第七段应该定义的是:执行的命令和参数。

via[mysql自动备份,cron,cron服务]

目前还没有任何评论.