解決方法: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# 查看/var/log/syslog
RUN sed -i '/session required pam_loginuid.so/c\#session required pam_loginuid.so' /etc/pam.d/crond
# 查看/var/log/syslog
/usr/local/bin/php think xxx# 查看/var/log/syslog
rrreee
4.修改/etc/pam.d/cron註解掉session required pam_loginuid.so
# 5、重新啟動cron,運作成功######還有就是,將這一行上是,將這一行加入dockerfile中###rrreee### crontab執行也遇到了一個坑,手動執行腳本沒有問題,因為讀取了環境變量,php要寫絕對路徑###rrreee###推薦學習:《## #docker影片教學###》###以上是docker怎麼解決crontab不生效的詳細內容。更多資訊請關注PHP中文網其他相關文章!