首頁  >  文章  >  運維  >  docker怎麼解決crontab不生效

docker怎麼解決crontab不生效

WBOY
WBOY原創
2022-08-16 18:18:367825瀏覽

解決方法: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

docker怎麼解決crontab不生效

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn