解决方法:1、排查容器内“/etc/init.d/crond status”是否为running状态;2、修改“/etc/pam.d/crond”文件,将其中的“required”修改为“sufficient”;3、利用“/etc/init.d/crond restart”重新启动crond服务即可。
本教程操作环境:linux7.3系统、docker19.03版、Dell G3电脑。
在docker中默认使用centos镜像,在该镜像中没有安装crond,通过yum安装成功后,crontab没有生效。
1、首先排查容器内 /etc/init.d/crond status 是否为running状态。
如果通过第一步还无法解决,参考下面的办法:
2、修改/etc/pam.d/crond文件,将其中的required改为sufficient,然后重启crond服务:/etc/init.d/crond restart
注意:在centos7的基础镜像里面好像没有该问题。
扩展知识
最早解决方案
1、在宿主机里面
1 3 * * * root cd /data/wwwroot/xxx && docker-compose exec app php think xxx >> /var/log/crontab_xxx.log
docker-compose exec app php think xxx一直执行不成功
2、然后在容器里面安装crontab,还是执行不成功,关键还没有相关日志。检查crontab也是启动的。 /etc/init.d/cron status
3、装上rsyslog, apt-get install rsyslog, service rsyslog start
查看 /var/log/syslog
Dec 25 09:07:07 1a8e4fd5c766 crontab[15120]: (root) BEGIN EDIT (root) Dec 25 09:07:34 1a8e4fd5c766 crontab[15120]: (root) REPLACE (root) Dec 25 09:07:34 1a8e4fd5c766 crontab[15120]: (root) END EDIT (root) Dec 25 09:08:01 1a8e4fd5c766 cron[15100]: (root) RELOAD (crontabs/root) Dec 25 09:08:01 1a8e4fd5c766 CRON[15133]: Cannot make/remove an entry for the sp
4、修改/etc/pam.d/cron
注释掉 session required pam_loginuid.so
5、重启cron,运行成功
还有就是,将这一行添加到dockerfile中
RUN sed -i '/session required pam_loginuid.so/c\#session required pam_loginuid.so' /etc/pam.d/crond
crontab执行还遇到了一个坑,手动执行脚本没有问题,因为读取了环境变量,php要写绝对路径
/usr/local/bin/php think xxx
推荐学习:《docker视频教程》
以上是docker怎么解决crontab不生效的详细内容。更多信息请关注PHP中文网其他相关文章!