如何在Linux中自定义定时调度任务以及依赖关系的配置
创始人
2025-05-31 23:19:40
0

内容目录

  • 一、定时调度任务
      • Cron的运行机制
  • 二、处理任务之间的依赖关系
  • 三、处理多任务之间的依赖关系

可以使用标准的Linux定时任务工具Cron来定时调度一个shell脚本。Cron是一个非常强大的工具,它可通过简单的命令来实现一些非常复杂的调度任务,比如每周五下午5点备份数据库,每小时发送一次邮件等。

一、定时调度任务

要定时调度一个脚本,首先需要编辑Cron的任务列表。可以使用下面的命令来打开任务列表:

shell crontab -e
这将会打开一个文本编辑器,允许你编辑Cron的任务列表。然后可以添加一个新的任务,比如要在每天早上6点运行一个脚本:

shell0 6 * * * /path/to/script.sh
这里的意思是,在每天的0点时(也就是午夜),Cron会调用一个名为/path/to/script.sh的脚本。更具体来说,这个任务将会在每天的早上6点时运行。

可以根据实际需要来修改这个任务的时间设置,比如:

shell 30 4 * * * /path/to/script.sh
这个任务将会在每天的4点30分运行。这个例子中,cron的时间格式如下:

*  *  *  *  *  command
┬    ┬    ┬    ┬    ┬
│    │    │    │    │
│    │    │    │    └───── 命令
│    │    │    └─────────── 在哪一天(0~7,0和7表示周日)
│    │    └──────────────── 哪一个月份(1~12)
│    └───────────────────── 哪一天(1~31)
└─────────────────────────── 每一分钟的哪一秒(0~59)

Cron的任务列表保存在用户的home directory下,可以使用下面的命令来查看当前用户的Cron任务列表:

shell crontab -l
如果需要删除一个任务,可以使用下面的命令:

shell rontab -r
这将会删除当前用户的所有任务。如果只想删除指定的任务,需要编辑Cron的任务列表,然后将要删除的任务行删除即可。

下面是详细说明以及一个示例:

Cron的运行机制

Cron是一个守护进程,它会不断地读取并执行/etc/crontab文件中的任务安排,文件中的任务安排包括了指定任务的时间、日期、执行的命令等信息。

编写/etc/crontab文件
/etc/crontab文件是系统级别的cron任务文件,它包含了所有需要定时调度的任务信息。文件格式如下:

* * * * * user-name command-to-be-executed

其中,五个星号依次代表了分钟、小时、日、月、星期,而命令则是需要执行的命令。星号代表任意时间,如果需要指定某个特定的时间,就需要将星号替换为对应的数字。例如:

0 2 * * * user-name command-to-be-executed

代表在每天凌晨2点时执行该任务。

示例
我们来看一个简单的示例,假设我们需要每天定时备份我们的数据库,我们可以编写一个名为backup.sh的shell脚本,脚本内容如下:

#!/bin/bash
# 备份数据库到指定目录
mysqldump -u username -p password mydatabase > /var/www/html/backup.sql
#接着,我们需要将该任务添加到/etc/crontab文件中:# 每天凌晨3点备份数据库
0 3 * * * root sh /path/to/backup.sh
#这条命令表示,在每个月的每一天的凌晨3点执行备份脚本。注意,我们在这里使用了root用户来执行命令,如果你想要使用其他用户来执行,就需要指定该用户的用户名。另外,最后还需要指定需要执行的脚本的路径。

到这里,我们就完成了一个简单的定时任务的设置,cron将会在每天凌晨3点调用backup.sh脚本来备份数据库。
***Mac中如何边界crontab文件
在Mac上,可以通过以下步骤编辑crontab文件:

打开终端应用程序。

运行以下命令以编辑当前用户的crontab文件:

crontab -e

在编辑器中,您可以添加新的cron作业或编辑现有作业。每个作业应该写在一行上,并以以下格式开头:
分钟 小时 日 月 星期 命令

编辑完毕后,按下Ctrl + X键,然后按下Y键保存更改。

重新启动cron守护进程以使更改生效:

sudo launchctl stop com.vix.cronsudo launchctl start com.vix.cron

注意:在编辑crontab文件之前,建议备份原始文件以防万一。

举个栗子
假设每分钟执行一段命令,像文件中写入一句 hello,date

  1. 实现:shell脚本
#!/bin/bash
echo "hello,  $(date +%Y-%m-%d\ %H:%M:%S)" >> hello.txt
  1. 编辑crontab文件:
# 每分钟调度shell脚本:echo_hello.sh
* * * * * sh echo_hello.sh
  1. 重新启动cron
sudo launchctl stop com.vix.cronsudo launchctl start com.vix.cron
  1. 监控是否正常调度
tail -f hello.txt
  1. 结果
hello,2023-03-21 16:00:00
hello,2023-03-21 16:01:00
hello,2023-03-21 16:02:00
hello,2023-03-21 16:03:00
hello,2023-03-21 16:04:00

二、处理任务之间的依赖关系

在cron定时调度中,可以通过在命令行中添加依赖关系来保证任务能够按照正确的顺序运行。具体来说,可以使用&&和||指令来声明任务之间的依赖关系。

使用&&指令来表示前一个任务成功执行后才会执行下一个任务,如:

0 12 * * * task1 && task2 && task3

上面的命令表示在每天中午12点执行task1,如果task1执行成功则会执行task2,如果task2也执行成功则会执行task3。

使用||指令来表示前一个任务执行失败后才会执行下一个任务,如:

*/5 * * * * task1 || task2

上面的命令表示每隔5分钟执行task1,如果task1执行失败则会执行task2。

三、处理多任务之间的依赖关系

如果两个任务同时依赖于同一个任务
可以通过在任务中添加执行顺序和间隔时间来实现任务之间的依赖关系。具体地,可以通过以下两种方式进行实现:

在任务脚本中添加判断逻辑,判断依赖任务是否已经完成,如果未完成,则等待一段时间后再执行当前任务。
例如:

#!/bin/bash
# 执行依赖任务
task1.sh# 判断依赖任务是否完成
while [ ! -f "task1.done" ]
do
# 如果未完成,则等待5秒后再检查
sleep 5
done# 执行当前任务
task2.sh

在上面的例子中,task1.sh是依赖任务,执行完后会生成一个task1.done的标识文件。然后在task2.sh中添加了一个循环,每次都检查task1.done文件是否存在,如果不存在,则等待5秒后再检查,直到文件存在为止。

使用专门的任务调度工具,如crontab,设置任务执行的先后顺序和时间间隔。
crontab是一个在Linux环境下用于创建、修改、删除cron任务的工具。通过在crontab文件中设置任务的执行时间和间隔,可以实现任务之间的依赖关系。

例如:

# 每5分钟执行一次任务1
*/5 * * * * task1.sh# 每10分钟执行一次任务2,并在任务1执行完成后执行
*/10 * * * * sleep $(find /path/to/task1.done -mmin -10) && task2.sh

在上面的例子中,任务1每5分钟执行一次,而任务2稍复杂一些。首先,我们使用sleep命令等待时间,该命令会等待一个时间段,这里使用了find命令来查找task1.done文件的修改时间,如果时间小于10分钟,则sleep命令会等待相应的时间,否则立即执行。接着,使用&&符号来连接两个命令,表示只有当第一个命令执行成功后才会执行第二个命令。

总体上,无论使用哪种方式实现任务之间的依赖关系,都需要考虑到任务的执行顺序和间隔时间,以确保任务可以按照正确的顺序执行,并且不会出现互相干扰的情况。

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...