linux定时任务crontab执行脚本无输出

写了一个备份数据库的脚本,手动调试时,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
  • 1
  • 2
  • 3
  • 4
  • 5

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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

这样,crontab在执行脚本的时候,就能正常执行。


猜你喜欢

转载自blog.csdn.net/qq_22083251/article/details/80620068