docker下创建crontab定时任务失败
创建过程
基础镜像采用的centos7.2,需要安装一下crontab,在dockerfile中加以下语句就可以了:
# crontab jobs
RUN yum -y install crontabs
ADD ./run/nlp-cron /etc/cron.d/nlp-cron
RUN chmod 0644 /etc/cron.d/nlp-cron
RUN crontab /etc/cron.d/nlp-cron
其中nlp-cron是定时任务的配置,内容是下面这样的:
* * * * * sh test.sh >/dev/null 2>&1
后来启动了镜像,发现定时任务并不能正常启动,于是开启了漫长的排错过程。
排错1
首先进入docker的容器,用crontab -l
看了一下,任务实际上是存在的,可以证明是任务没有启动/执行成功而已。
同时在容器中,执行了一下想要做的操作,发现没有任何问题,说明代码没有问题。
排错2
创建镜像的过程是参考这里做的,按理说不缺什么步骤,于是又按照他的过程重新弄了一下,发现系统命令可以执行。
此时又问了一下同事,说最好用全路径。我本身执行的是python命令,于是whereis python
找了一下全路径,改了之后,发现还是没有执行成功。
于是在py文件里加了各种print,发现一个问题写文件的操作不能执行……经同事提醒,试了一下全路径,居然改好了。
排错3
过了2天,功能完善后,想打包再试一下,发现又不行了……这次日志显示的是缺一个环境变量,于是找了半天办法。最终,在bash_profile中添加了环境变量,才解决了这个问题。
export LD_LIBRARY_PATH=/usr/lib/xxx:$LD_LIBRARY_PATH
export PATH
排错4
在排错期间,网上很多人说到是权限验证的问题。要改下面这个地方,/etc/pam.d/crond:
#
# The PAM configuration file for the cron daemon
#
#
# No PAM authentication called, auth modules not needed
account required pam_access.so
account include password-auth
session sufficient pam_loginuid.so
session include password-auth
auth include password-auth
排错5
打包之后,起了容器,可能还会遇到不执行的问题,此时可以尝试重启crontab。试了一下在dockerfile中加 RUN crond restart
,发现不管用。
此时可以尝试起了容器之后,执行一个下面的命令:
docker exec -it container_id crond restart
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· 手把手教你在本地部署DeepSeek R1,搭建web-ui ,建议收藏!
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 数据库服务器 SQL Server 版本升级公告
· C#/.NET/.NET Core技术前沿周刊 | 第 23 期(2025年1.20-1.26)
· 程序员常用高效实用工具推荐,办公效率提升利器!