在 CentOS 系统中,使用 crontab 本身无法直接实现任务的并发控制。但是,你可以通过以下方法来实现类似的功能:
创建一个脚本(例如:run_concurrently.sh),并在其中使用 flock 命令来实现文件锁。这样,当一个任务正在运行时,其他任务将被阻止执行。
#!/bin/bash
# 创建一个锁文件
lockfile="/tmp/my_cronjob.lock"
# 使用 flock 命令尝试获取锁
if ! flock -n $lockfile -c true; then
echo "Cron job is already running. Exiting."
exit 1
fi
# 在这里执行你的任务
echo "Cron job started."
# your commands here
echo "Cron job finished."
# 删除锁文件
rm -f $lockfile
确保脚本具有可执行权限:
chmod +x run_concurrently.sh
然后在 crontab 中添加以下条目:
* * * * * /path/to/run_concurrently.sh
在脚本中检查是否有相同名称的进程已经在运行。如果有,则退出脚本。这种方法不如使用文件锁可靠,但在某些情况下可能足够。
#!/bin/bash
# 检查是否有相同名称的进程已经在运行
if pgrep -f "my_cronjob_script" > /dev/null; then
echo "Cron job is already running. Exiting."
exit 1
fi
# 在这里执行你的任务
echo "Cron job started."
# your commands here
echo "Cron job finished."
然后在 crontab 中添加以下条目:
* * * * * /path/to/your_script.sh
请注意,这些方法只能在一定程度上实现并发控制。如果你需要更高级的并发控制,可以考虑使用其他任务调度工具,如 Celery、APScheduler 或 Kubernetes CronJob。