mysql-full-backup.sh
#!/bin/bash export MYSQL_HOME=/usr/local/Percona-Server-5.5.21-rel25.0-227.Linux.x86_64/ export PATH=$MYSQL_HOME/bin:$PATH mysql_backup_dir=/data/backup/mysql/ mysql_username="YOURS" mysql_password="YOURS" cd $mysql_backup_dir lastincrementfolder=`ls -l|grep ^d|tail -n 1 | awk '{print $9}'` timeStart=$(date '+%Y%m%d%H%M%S') logfile=full-$timeStart.log innobackupex --user=$mysql_username --password=$mysql_password $mysql_backup_dir 2> "$logfile"
mysql-incremental-backup.sh
#!/bin/bash export MYSQL_HOME=/usr/local/Percona-Server-5.5.21-rel25.0-227.Linux.x86_64/ export PATH=$MYSQL_HOME/bin:$PATH mysql_backup_dir=/data/backup/mysql/ mysql_username="YOURS" mysql_password="YOURS" cd $mysql_backup_dir lastincrementfolder=`ls -l|grep ^d| tail -n 1 | awk '{print $9}'` timeStart=$(date '+%Y%m%d%H%M%S') logfile=increment-$timeStart.log innobackupex --incremental $mysql_backup_dir --incremental-basedir=$lastincrementfolder --user=$mysql_username --password=$mysql_password 2> "$logfile"
注意里面的
export PATH=$MYSQL_HOME/bin:$PATH
不加的话报mysql,innobackupex等 command not found!
以上两个脚本放在/usr/local/scripts/ 目录下,接下来配置crontab
crontab -e
添加以下内容:
0 2 * * 1-6 sh /usr/local/scripts/mysql-incremental-backup.sh 0 2 * * 0 sh /usr/local/scripts/mysql-full-backup.sh
然后使用vi的保存命令(ZZ,或者:wq)保存 !
意思是每周一到周六的02:00执行一次增量备份,每周日02:00执行一次全量备份。
下面是crontab的时间格式,备忘用。
段 |
含义 |
取值范围 |
第一段 |
代表分钟 |
0—59 |
第二段 |
代表小时 |
0—23 |
第三段 |
代表日期 |
1—31 |
第四段 |
代表月份 |
1—12 |
第五段 |
代表星期几,0代表星期日 |
0—6 |
附几个网上找的例子:
● 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命令