目前,我有一个Django wsgi来处理网络流量。 (我有一个nginx作为前端来转发到wsgi的流量)
现在,我想启动一个crontab服务,运行定期后台工作。
这就是我所做的
FROM python:3.6.4-alpine3.4
...
RUN chmod +x entrypoint.sh
ENTRYPOINT ["sh", "entrypoint.sh"]
CMD /usr/local/bin/gunicorn web.wsgi:application -b django:5000 --log-level=info --error-logfile=/var/log/gunicorn3.err.log
#!/bin/sh
...
python manage.py crontab add
# https://stackoverflow.com/questions/37015624/how-to-run-a-cron-job-inside-a-docker-container
#
# "crond -help" yields:
#
# -f Foreground
# -b Background (default)
# -S Log to syslog (default)
# -l N Set log level. Most verbose:0, default:8
# -d N Set log level, log to stderr
# -L FILE Log to FILE
# -c DIR Cron dir. Default:/var/spool/cron/crontabs
# start cron
/usr/sbin/crond -f -l 8
exec "$@"
django:
build:
context: ./django
dockerfile: Dockerfile
restart: always
depends_on:
- pgbouncer
expose:
- "5000"
volumes:
- static_data:/app/static
如果我使用上面的设置,我会注意到。
首先,我尝试改变django\entrypoint.sh
# start cron
/usr/sbin/crond -f -l 8
至
# start cron
/usr/sbin/crond -b -l 8
做出上述改变后,
我可以知道为什么会这样吗?如何让我的django
容器服务于网络流量,同时运行cron作业?
或者,这不是在Docker中做这种事情的正确方法吗?我应该用2个容器?
我会在第二个容器上运行一个完整的第二个容器,在compose文件cron
中命名服务或类似的东西(如果你有多个crons,可能更具体到实际的工作)。每个容器1个过程是一般做法。在“cron”容器中我甚至不会通过crond
运行它我会在主机上使用我正在使用的任何东西来处理容器的调度。我将你的工作从django-cron
改为自定义的django-admin
命令,因为你将不再使用django app来管理它的运行。你仍然可以在django上建立第二个容器,只需用CMD
文件docker-compose.yml
更改command: ["django-admin", "mycommand"]
即可。可能没有必要暴露第二个容器上的端口。作为正常服务docker-compose run mycronservice
调用