首页 > 运维 > Docker > docker怎么解决crontab不生效

docker怎么解决crontab不生效

WBOY
发布: 2022-08-16 18:18:36
原创
7872 人浏览过

解决方法:1、排查容器内“/etc/init.d/crond status”是否为running状态;2、修改“/etc/pam.d/crond”文件,将其中的“required”修改为“sufficient”;3、利用“/etc/init.d/crond restart”重新启动crond服务即可。

docker怎么解决crontab不生效

本教程操作环境: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

555.png

注意:在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中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板