>首页> IT >

全球速读:docker怎么解决crontab不生效

时间:2022-08-16 18:56:45       来源:PHP中文网

本教程操作环境:linux7.3系统、docker19.03版、Dell G3电脑。


(资料图片)

docker怎么解决crontab不生效

在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中文网其它相关文章!

关键词: 相关文章 还有就是 好像没有