crontab 中的任务命令行正常,但是不被调度不执行的原因

问题描述

同事在docker里部署了一个nginx,然后用certbot获取的证书。

但是certbot在docker里自动刷新证书有效期(renew)的操作没执行。

咱也不是很熟docker里的nginx如何配置certbot自动刷新,偷个懒,在外面执行docker exec 调用就算了----原本是这么计划的

结果写了个脚本,调试完成,测试成功,就差一步了:把它放crontab任务里,每周日0:00执行一下,它就是不被调度。

定位过程

首先咱是在网上搜索有没有前辈碰到这个问题,挨个检查了权限,环境变量这些,确定咱的脚本没问题。 然后就卡住了。

自己想办法把,从头开始。

在crontab里搞个任务

javascript 复制代码
*/1 * * * * /bin/echo `date` >> /root/1.log

最直接了,root用户直接上,只执行个echo。

结果不得行,它也不被调度 🥹

使用crontab -l查看任务的时候发现它是这个样子的

ruby 复制代码
root@0003:~# crontab -l 
root@0003:~# bin/echo `date` >> /root/1.log of crontab(5) and cron(8)

???嗯?

直接 vi /var/spool/cron/crontabs/root 一看, 好家伙,一堆^M在里面,解析不出来任务啊!

原因找到,原来是文件格式不对。

解决方式

简单的把任务内容备份下来,然后把原始文件内容全删了,重新用crontab -e粘贴进去 保存退出后crontab -l一看,正常了! 继续监视那个1.log ,也正常了。 删了1.log的那个任务,刷新任务也测试了,正常调度。

ok, 收工了。

总结

cron任务脚本正常,但是不调度的原因又多了一条:crontab 文件格式不正确。

现在发现crontab中的任务不执行的检查清单是:

  1. 先命令行检查脚本可以正确执行
  2. 再用service cron status确认服务是启动的
  3. 再用crontab -l来检查任务是可以被正确解析的 本文就是这里发现没有正确的显示所有的任务,才想起来去查看文件格式的
  4. 全部正确,再检查任务描述里的时间这些写对没
  5. 检查环境变量:在脚本里打印使用到的变量和命令的路径

补充

后来进docker看了一下,docker里默认没有cron服务,而certbot是用它来做自动更新的,所以docker里的certbot不会定时自动更新

相关推荐
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue蛋糕店管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
没差c2 小时前
springboot集成flyway
java·spring boot·后端
三水不滴2 小时前
Redis 过期删除与内存淘汰机制
数据库·经验分享·redis·笔记·后端·缓存
笨蛋不要掉眼泪3 小时前
Spring Boot集成LangChain4j:与大模型对话的极速入门
java·人工智能·后端·spring·langchain
sheji34166 小时前
【开题答辩全过程】以 基于SpringBoot的疗养院管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
短剑重铸之日6 小时前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
码界奇点7 小时前
基于Flask与OpenSSL的自签证书管理系统设计与实现
后端·python·flask·毕业设计·飞书·源代码管理
代码匠心9 小时前
从零开始学Flink:状态管理与容错机制
java·大数据·后端·flink·大数据处理
分享牛9 小时前
LangChain4j从入门到精通-11-结构化输出
后端·python·flask
知识即是力量ol10 小时前
在客户端直接上传文件到OSS
java·后端·客户端·阿里云oss·客户端直传