Cronjob 脚本未按预期工作

Cronjob script isn't working as expected

我有一个脚本,当我自己手动 运行 时它工作得很好,但似乎不能从 crontab 正确地 运行。

主要错误是未设置(外部)环境变量。

我在 cronjob 定义上方添加了 SHELL=/bin/bash,但仍然出现相同的错误。

我在下面复制并粘贴的脚本。为帮助干杯

#!/bin/bash
# export MYSQL_PORT_3306_TCP_ADDR=`awk 'NR==1 {print }' /etc/hosts`

set -e

MOUNT=/mnt/s3b/
BACKUP=/root/backups
mkdir -p $BACKUP
NOW=$(date +"%Y-%m-%d-%H%M")
DB_FILE="$MYSQL_ENV_MYSQL_DATABASE.$NOW.sql"

/usr/bin/s3fs <bucket_name> $MOUNT -ouse_cache=/tmp -odefault_acl=public-read -ononempty

mysqldump -h$MYSQL_PORT_3306_TCP_ADDR -uroot -p$MYSQL_ENV_MYSQL_ROOT_PASSWORD $MYSQL_ENV_MYSQL_DATABASE > /tmp/$DB_FILE

tar -czvf $BACKUP/"$DB_FILE.tar.gz" -P /tmp/$DB_FILE

cp $BACKUP/"$DB_FILE.tar.gz" $MOUNT/data/

如您在所有环境变量下方看到的错误 return:

 May 11 00:17:59 fcf074b9e5ee kernel: [293368.874868] SELinux: mount invalid.    Same superblock, different security settings for (dev mqueue, type mqueue)
 May 11 00:18:14 fcf074b9e5ee kernel: [293383.903080] docker0: port 6(veth2f6467f) entered forwarding state
 May 11 01:29:26 fcf074b9e5ee s3fs[78]: s3fs.cpp:s3fs_init(3334): init v1.79(commit:unknown) with OpenSSL
 May 11 01:29:26 fcf074b9e5ee s3fs[78]: s3fs.cpp:s3fs_check_service(3729):     Could not connect wrong region us-east-1, so retry to connect region eu-west-1.
 May 11 01:31:10 fcf074b9e5ee s3fs[93]: s3fs.cpp:s3fs_init(3334): init v1.79(commit:unknown) with OpenSSL
 May 11 01:31:10 fcf074b9e5ee s3fs[93]: s3fs.cpp:s3fs_check_service(3729): Could not connect wrong region us-east-1, so retry to connect region eu-west-1.
  May 11 10:25:02 fcf074b9e5ee kernel: [329791.913331] hrtimer: interrupt took 2331455 ns

  mysqldump -h -uroot -p > /tmp/.2016-05-11-0015.sql

正如@that-other-guy 指出的那样,环境变量 $MYSQL_ENV_MYSQL_DATABASE、$MYSQL_ENV_MYSQL_ROOT_PASSWORD 未设置。

当进程分叉时,环境变量从进程继承到子进程。这意味着 crontab 作业将从 crontab 服务继承环境。安装 crontab 作业时 shell 中设置的环境变量将不会被保留。

您应该在 shell 脚本中添加:

MYSQL_ENV_MYSQL_DATABASE="mydatabase"
MYSQL_ENV_MYSQL_ROOT_PASSWORD="mypassword"