数据库采用crontab调用xtrabackup备份。
但是我惊奇的发现,备份居然没有执行。
备份脚本如下
![](//img.blog.itpub.net/blog/attachment/201406/9/29254281_14022841668ygZ.jpg?x-oss-process=style/bb)
backup.sh 脚本如下
但是..
crontab不能应用用户的环境变量,也就是说他找不到innobackupex这个命令...
![](//img.blog.itpub.net/blog/attachment/201406/9/29254281_1402284304yRPY.jpg?x-oss-process=style/bb)
而脚本中的 innobackupex 则在用户自己定义的PATH中,解决这个问题有三个方法
1.在/etc/crontab中增加PATH变量
2.在脚本中使用绝对路径
3.在脚本中引入用户环境变量。
我感觉第三种方法比较可行。
但是我惊奇的发现,备份居然没有执行。
备份脚本如下
![](http://img.blog.itpub.net/blog/attachment/201406/9/29254281_14022841668ygZ.jpg?x-oss-process=style/bb)
backup.sh 脚本如下
#!/bin/bash TODAY=`date +%Y%m%d` BACKUPDIR=/data/dbbak/${TODAY} mkdir ${BACKUPDIR} cd ${BACKUPDIR} innobackupex --user=root --port=3306 ${BACKUPDIR} DAYSAGO=`date -d \'3 days ago\' +%Y%m%d` rm -rf /data/dbbak/${DAYSAGO}
看起来似乎没有什么问题。但是..
crontab不能应用用户的环境变量,也就是说他找不到innobackupex这个命令...
![](http://img.blog.itpub.net/blog/attachment/201406/9/29254281_1402284304yRPY.jpg?x-oss-process=style/bb)
而脚本中的 innobackupex 则在用户自己定义的PATH中,解决这个问题有三个方法
1.在/etc/crontab中增加PATH变量
2.在脚本中使用绝对路径
3.在脚本中引入用户环境变量。
我感觉第三种方法比较可行。
#!/bin/bash export PATH=.:$PATH:/home/mysql/mysql-5.6.14/bin:/home/mysqlbackup/percona-xtrabackup-2.1.9-Linux-x86_64/bin; TODAY=`date +%Y%m%d` BACKUPDIR=/data/dbbak/${TODAY} mkdir ${BACKUPDIR} cd ${BACKUPDIR} innobackupex --user=root --port=3306 ${BACKUPDIR} DAYSAGO=`date -d \'3 days ago\' +%Y%m%d` rm -rf /data/dbbak/${DAYSAGO}
幸亏发现的早..来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29254281/viewspace-1178626/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29254281/viewspace-1178626/