系统范围 cron 中的环境变量



我最近不得不从基于 pythonAlpine的映像切换到所谓的 python:3.7.2-slim(基于 Debian(。我的 cron 作业似乎不再工作,因为环境变量不再可用于 cron。我通过这个测试脚本得出了这个结论:

# run.py
import os, sys
with open("/var/log/lastlog", "a") as f:
try:
user = os.environ['INFLUXDB_USER'] or "None"
f.write("I am running python as {} with {}n".format(user, sys.version_info[:3]))
except Exception as e:
f.write("I failed: {}n".format(str(e)))

和这个 crontab

# /etc/crontab: system-wide crontab
# Unlike any other crontab you don't have to run the `crontab'
# command to install the new version when you edit this file
# and files in /etc/cron.d. These files also have username fields,
# that none of the other crontabs do.
SHELL=/bin/bash
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
# m h dom mon dow user  command
17 *    * * *   root    cd / && run-parts --report /etc/cron.hourly
25 6    * * *   root    test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily )
47 6    * * 7   root    test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.weekly )
52 6    1 * *   root    test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.monthly )
# ADDED 
*/1 * * * * root . /root/.bashrc; python3.7 /usr/src/collector/run.py
*/1 * * * * root echo 'hi' >> /var/log/lastlog

异常显示,当脚本由 cron 运行时找不到INFLUXDB_USER,但在手动运行时(或在 python shell 中询问os.environ['INFLUXDB_USER']时(会找到。

我尝试了什么

  • 获取命令(通过在它前面添加. /root/.bashrc;(也尝试. /root/.profile;((
  • source /root/.bashrc之后立即将其放入不同的 shell 脚本
  • 使用绝对路径
  • 使用 bash 登录来运行命令源
  • cron.d中移动说明
  • 使用crontab-e添加命令,而不是直接编辑/etc/crontab

由于 ENV 变量未在/etc/environment中定义,我不确定这个">系统范围 Cron"是否可以以任何方式访问它们。与我必须在 Alpine 中编辑的/etc/crontab/root相比,我发现这个 cron 非常令人困惑(它立即起作用(。您如何处理这个">系统范围的 crontab"?这是 Debian 的一个特点吗?

编辑

  • 版本:cron/oldstable,now 3.0pl1-128+deb9u1 amd64
  • 用Docker定义的env变量存储在/proc/1/environ中(但采购它并没有改变任何事情(

我能找到的唯一直接方法是通过稍微调整 Docker 映像的entrypoint.sh直接编写/etc/crontab中的变量。这是一种在使用sedSHELL=/bin/sh后添加它们的方法

sed -i "/SHELL=/bin/sh/a INFLUXDB_USER=$INFLUXDB_USER" /etc/crontab
sed -i "/SHELL=/bin/sh/a PROJECT_NAME=$PROJECT_NAME" /etc/crontab
sed -i "/SHELL=/bin/sh/a INFLUXDB_USER_PASSWORD=$INFLUXDB_USER_PASSWORD" /etc/crontab
sed -i "/SHELL=/bin/sh/a INFLUXDB_DB=$INFLUXDB_DB" /etc/crontab
printf "3 */1 * * * root python /usr/src/collector/coin.py fetch cmcn" >> /etc/crontab
printf "30 0 * * 4 root python /usr/src/collector/coin.py fetch gt --mode weeklyn" >> /etc/crontab
service cron restart
chmod 640 /etc/crontab

我对它不是很满意,所以欢迎任何更优雅的解决方案。

最新更新