写了一个备份数据库的脚本,手动调试时,OK。
写入crontab后,脚本失效。
异常原因:用户环境变量问题
看一下脚本调用的是mysqldump,MySQL是编译安装的:安装路径/usr/local/mysql。
因为在Linux下用crontab执行定时任务时不会从用户profile文件中读取环境变量参数,所以导致在手动执行某个脚本时是成功的,但是写入crontab中定期执行时会出错。
根本原因是某些命令无法使用crontab调用,因为用户登陆Linux操作系统的时候,”/etc/profile”, “~/.bash_profile”等配置文件会被自动执行,所以手动执行脚本能够成功,但是crontab执行失败。
解决方法有两种:
1、在脚本文件文件里面调用的命令写成绝对路径:
#!/bin/bash
date=$(date +%d-%m-%Y)
/usr/local/mysql/bin/mysqldump -u root -p'xxx' xxx > /data/sdv1/mysqlbak/$date-xxx.sql
echo `date +%Y-%m-%d` >> /data/sdv1/mysqlbak/$date.log
echo 'Backup Successfully Completed' >> /data/sdv1/mysqlbak/$date.log
2、脚本文件添加环境变量:
#!/bin/bash
. /etc/profile
. ~/.bash_profile
date=$(date +%d-%m-%Y)
mysqldump -u root -p'xxx' xxx > /data/sdv1/mysqlbak/$date-xxx.sql
echo `date +%Y-%m-%d` >> /data/sdv1/mysqlbak/$date.log
echo 'Backup Successfully Completed' >> /data/sdv1/mysqlbak/$date.log
这样,crontab在执行脚本的时候,就能正常执行。