如何在docker容器中运行cron作业?

Suk*_*djf 6 cron scheduled-tasks docker dockerfile

我有一个 python 脚本,用于填充 AWS 中的 Postgres 数据库。

我能够手动运行它并且它正在将数据加载到数据库中而没有任何问题。我想在 docker 容器内每 5 分钟运行一次。

所以我将它包含在 docker 镜像中运行。但我不确定为什么它没有运行。我看不到任何附加到/var/log/cron.log文件的内容。有人可以帮我弄清楚为什么它没有运行吗?

我能够在 docker build 期间将脚本复制到图像并能够手动运行它。正在填充数据库,我得到了预期的输出。

脚本位于当前目录中,该目录将被复制到/code/文件夹中

这是我的代码:

Dockerfile:

FROM python:3
RUN apt-get -y update && apt-get -y upgrade
RUN apt-get install -y cron
RUN apt-get install -y postgresql-client
RUN touch /var/log/cron.log
ENV PYTHONUNBUFFERED 1
RUN mkdir /code
WORKDIR /code
ADD . /code/
COPY crontab /etc/cron.d/cjob
RUN chmod 0644 /etc/cron.d/cjob
CMD cron && tail -f /var/log/cron.log
Run Code Online (Sandbox Code Playgroud)

定时任务:

*/5 * * * * python3 /code/populatePDBbackground.py >> /var/log/cron.log
# Empty line
Run Code Online (Sandbox Code Playgroud)

Nic*_*lay 14

Crontab 需要额外的字段:用户,谁运行命令:

* * * * * root python3 /code/populatePDBbackground.py >> /var/log/cron.log
# Empty line
Run Code Online (Sandbox Code Playgroud)

Dockerfile是:

FROM python:3
RUN apt-get -y update && apt-get -y upgrade
RUN apt-get install -y cron postgresql-client
RUN touch /var/log/cron.log
RUN mkdir /code
WORKDIR /code
ADD . /code/
COPY crontab /etc/cron.d/cjob
RUN chmod 0644 /etc/cron.d/cjob
ENV PYTHONUNBUFFERED 1
CMD cron -f
Run Code Online (Sandbox Code Playgroud)

测试python脚本populatePDBbackground.py是:

from datetime import datetime

print('Script has been started at {}'.format(datetime.now()))
Run Code Online (Sandbox Code Playgroud)

最后我们得到:

$ docker run -d b3fa191e8822
b8e768b4159637673f3dc4d1d91557b374670f4a46c921e0b02ea7028f40e105

$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
b8e768b41596        b3fa191e8822        "/bin/sh -c 'cron -f'"   4 seconds ago       Up 3 seconds                            cocky_beaver

$ docker exec -ti b8e768b41596 bash
root@b8e768b41596:/code# tail -f /var/log/cron.log
Script has been started at 2019-03-13 00:06:01.095013
Script has been started at 2019-03-13 00:07:01.253030
Script has been started at 2019-03-13 00:08:01.273926
Run Code Online (Sandbox Code Playgroud)