news 2026/6/15 17:56:08

Linux定时任务cron完全指南:从写法到排错

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux定时任务cron完全指南:从写法到排错

定时任务谁都会用,但出问题的时候很多人抓瞎——任务没跑、跑了报错、跑了但没效果。

这篇把cron彻底讲清楚,包括怎么写、怎么调试、怎么排错。

crontab基础

编辑定时任务

# 编辑当前用户的crontabcrontab-e# 查看当前用户的crontabcrontab-l# 删除当前用户的所有crontab(危险)crontab-r# 编辑指定用户的crontab(需要root)crontab-u nginx -e

时间格式

分 时 日 月 周 命令 * * * * * command

五个时间字段:

  • 分:0-59
  • 时:0-23
  • 日:1-31
  • 月:1-12
  • 周:0-7(0和7都是周日)

常用写法

# 每分钟* * * * * /path/to/script.sh# 每小时的第30分钟30* * * * /path/to/script.sh# 每天凌晨2点02* * * /path/to/script.sh# 每天上午9点和下午6点09,18* * * /path/to/script.sh# 每隔5分钟*/5 * * * * /path/to/script.sh# 每隔2小时0*/2 * * * /path/to/script.sh# 工作日每天9点09* *1-5 /path/to/script.sh# 每月1号凌晨001* * /path/to/script.sh# 每周日凌晨3点03* *0/path/to/script.sh

特殊写法

@reboot /path/to/script.sh# 重启后执行一次@yearly /path/to/script.sh# 每年1月1日0点@monthly /path/to/script.sh# 每月1日0点@weekly /path/to/script.sh# 每周日0点@daily /path/to/script.sh# 每天0点@hourly /path/to/script.sh# 每小时0分

容易踩的坑

坑1:环境变量

这是最常见的问题。

cron执行任务时的环境变量和你在终端里不一样。PATH可能只有/usr/bin:/bin,很多命令找不到。

解决方法1:用绝对路径

# 错误02* * * python /home/user/script.py# 正确02* * * /usr/bin/python3 /home/user/script.py

解决方法2:在crontab开头定义环境变量

PATH=/usr/local/bin:/usr/bin:/binSHELL=/bin/bash02* * * python3 /home/user/script.py

解决方法3:在脚本开头source环境

#!/bin/bashsource/home/user/.bashrc# 后面的代码...

坑2:工作目录

cron执行时的工作目录是用户home目录,不是脚本所在目录。

# 脚本里用相对路径会出问题cd/home/user/project python script.py# 找不到# 正确做法:在脚本里cd#!/bin/bashcd/home/user/project||exitpython script.py

坑3:输出没处理

cron默认把输出发邮件。如果没配邮件,输出就丢了,出错也不知道。

# 把输出重定向到日志02* * * /path/to/script.sh>>/var/log/myjob.log2>&1# 如果不关心输出,丢到黑洞02* * * /path/to/script.sh>/dev/null2>&1

2>&1是把标准错误也重定向到标准输出,别漏了。

坑4:权限问题

# 脚本没有执行权限chmod+x /path/to/script.sh# 或者用解释器调用02* * * /bin/bash /path/to/script.sh

坑5:特殊字符

crontab里%有特殊含义(换行),要转义:

# 错误02* * *echo"$(date+%Y-%m-%d)">>/var/log/test.log# 正确02* * *echo"$(date+\%Y-\%m-\%d)">>/var/log/test.log# 或者放到脚本里,脚本里不用转义

调试方法

手动执行测试

先在命令行里把命令跑一遍,确认没问题。

/bin/bash /path/to/script.sh

模拟cron环境

cron的环境很干净,可以模拟:

env-i /bin/bash --noprofile --norc -c'/path/to/script.sh'

如果这样跑不通,说明脚本依赖了某些环境变量。

查看cron日志

# Debian/UbuntugrepCRON /var/log/syslog# CentOS/RHELgrepCRON /var/log/cron# 实时看tail-f /var/log/syslog|grepCRON

能看到任务有没有被触发:

Dec 27 02:00:01 server CRON[12345]: (user) CMD (/path/to/script.sh)

给任务加日志

02* * * /path/to/script.sh>>/var/log/myjob.log2>&1

脚本里也加一些输出:

#!/bin/bashecho"=====$(date)====="echo"开始执行..."# 业务逻辑echo"执行完成"

检查cron服务

# 看服务状态systemctl statuscron# Debian/Ubuntusystemctl status crond# CentOS/RHEL# 重启服务systemctl restartcron

系统级crontab

除了用户的crontab,还有系统级的。

# 系统crontab文件/etc/crontab# 系统cron目录/etc/cron.d/# 自定义任务/etc/cron.hourly/# 每小时执行/etc/cron.daily/# 每天执行/etc/cron.weekly/# 每周执行/etc/cron.monthly/# 每月执行

/etc/crontab格式多一个用户字段:

# 分 时 日 月 周 用户 命令02* * * root /path/to/script.sh

往/etc/cron.daily/里放脚本,每天会自动执行。脚本不需要crontab格式,就是普通shell脚本,但要有执行权限。

进阶用法

任务不要重叠执行

如果任务跑的时间长,可能上一次还没跑完,下一次又开始了。

用flock加锁:

* * * * * flock -n /tmp/myjob.lock /path/to/script.sh

-n表示非阻塞,拿不到锁就直接退出。

或者在脚本里自己实现:

#!/bin/bashLOCKFILE=/tmp/myjob.lockif[-f"$LOCKFILE"];thenecho"任务正在运行,退出"exit0fitrap"rm -f$LOCKFILE"EXITtouch"$LOCKFILE"# 业务逻辑

随机延迟

避免所有机器同时跑任务,压力集中:

02* * *sleep$((RANDOM \%300))&&/path/to/script.sh

随机睡0-300秒再执行。

超时控制

防止任务跑太久:

02* * *timeout3600/path/to/script.sh

超过1小时就kill掉。

通知执行结果

02* * * /path/to/script.sh||echo"任务失败"|mail -s"cron告警"admin@example.com

或者用钉钉/飞书webhook:

#!/bin/bash# script.sh# 业务逻辑result=$?if[$result-ne0];thencurl-s -X POST"https://oapi.dingtalk.com/robot/send?access_token=xxx"\-H"Content-Type: application/json"\-d'{"msgtype":"text","text":{"content":"定时任务执行失败"}}'fi

常用场景

日志轮转

00* * *find/var/log/myapp -name"*.log"-mtime +7 -delete

删除7天前的日志。

数据库备份

03* * * mysqldump -u root -pxxx mydb|gzip>/backup/mydb_$(date+\%Y\%m\%d).sql.gz

同步文件

0* * * *rsync-avz /data/ user@backup:/backup/data/

监控检查

*/5 * * * * /usr/local/bin/check_service.sh

清理临时文件

04* * *find/tmp -type f -atime +3 -delete

cron本身不复杂,坑主要在环境变量和错误处理上。

记住几个原则:

  1. 用绝对路径
  2. 重定向输出到日志
  3. 加锁防止重叠
  4. 失败要有通知

这样基本就不会出问题了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 7:39:34

智能一卡通系统(包括门禁、梯控、闸机、水控、电控、消费机、访客机、考勤机、在线巡更等)在日常运行中,可能出现操作调试工具使用不当、读写卡失败、开卡失败或上位机通讯不上等问题。怎么解决?看这里,全程免费

智能一卡通系统常见问题排查指南智能一卡通系统(包括门禁、梯控、闸机、水控、电控、消费机、访客机、考勤机、在线巡更等)在日常运行中,可能出现操作调试工具使用不当、读写卡失败、开卡失败或上位机通讯不上等问题。这些问题通常源于软件配…

作者头像 李华
网站建设 2026/6/15 13:50:46

使用TensorRT优化通义千问推理性能实测报告

使用TensorRT优化通义千问推理性能实测报告 在大模型落地的浪潮中,一个绕不开的问题是:如何让千亿参数的“巨无霸”跑得又快又稳? 以通义千问为代表的大型语言模型(LLM),虽然具备强大的语义理解和生成能力…

作者头像 李华
网站建设 2026/6/15 15:10:38

使用TensorRT优化Google PaLM模型小型化版本

使用TensorRT优化Google PaLM模型小型化版本 在大语言模型日益普及的今天,一个现实问题摆在开发者面前:如何让像PaLM这样能力强大的模型,真正跑得快、用得起?原始的百亿甚至千亿参数模型虽然智能水平惊人,但推理延迟动…

作者头像 李华
网站建设 2026/6/15 13:50:42

企业战略执行像打怪?战略落地8化陪你步步升级

点个红心,收藏起来,这可能是你今年听到的价值百万的战略框架!很多老板跟我聊,说战略规划做得特别漂亮,但一到执行就变形,团队使不上劲,业绩上不去。问题到底出在哪?今天我给你一个完…

作者头像 李华
网站建设 2026/6/15 13:53:24

【开题答辩全过程】以 基于SpringBoot的智慧商城系统设计与实现为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人,语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华
网站建设 2026/6/15 16:11:34

屹晶微 EG2113D 高压 600V 半桥 MOS 管驱动芯片技术解析

一、芯片核心定位EG2113D 是屹晶微电子在 EG2113S 基础上优化推出的一款 高压半桥栅极驱动器 其核心价值在于 600V 高端悬浮耐压、2A/2A 强驱动电流、内置死区与闭锁保护、10V-20V 单电源供电 以及 支持最高 500kHz 开关频率 专为 无刷电机驱动器、正弦波/方波逆变器、电动车控…

作者头像 李华