首頁> 運維> Docker> 主體

docker怎麼解決crontab不生效

WBOY
發布: 2022-08-16 18:18:36
原創
7694 人瀏覽過

解決方法: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中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!