目前我正在尝试做这样的事情:
- 1 个 cron 作业 backup_daily
- 2 cron 作业 backup_weekly
- 3 cron 作业备份_月度
因此,可能发生的情况是,例如每天和每周将在同一天运行。至少其中一个会失败,因为应该备份的文件被另一个备份进程锁定。因此,一种简单的解决方案是在不同时间运行作业。但是由于我们不能准确地说出一份工作需要多长时间,所以这有点难看。
所以我在想的是一个代理脚本,所以我不会做上面的 cron 工作,而是做类似的事情
- 1 cron 作业 check_if_anybackup_is_running_and_run_backup_daily_else_wait_till_finished
- 2 cron 作业 check_if_anybackup_is_running_and_run_backup_weekly_else_wait_till_finished
- 3 cron 作业 check_if_anybackup_is_running_and_run_backup_monthly_else_wait_till_finished
那么我唯一关心的是它们以任何时间的偏移量开始,这样它们就不会相互阻塞。还应该明智地选择“等待”时间,这样他们就不会在同一时刻“重新检查”并再次相互阻塞(对于 3 个进程,我们可以使用偏移量 +1 每周处理,+2 处理每月,甚至/不均匀的计数器复查时间)
但是,我不确定如何使用 linux 脚本来实现这一点。我不确定“正确”的程序是什么。使用在进程启动时创建的锁定文件并检查它?如果它被锁定会发生什么?只是使用睡眠并在时间 X 之后再次检查锁定文件是一种“好”的方法吗?我不确定当我在 linux 线程上使用 sleep 时会发生什么 - 我的意思是:“计数器”是否已调度并耗尽处理器功率,或者是否存在某种中断,处理器将在一段时间后发送给等待的进程X(比如“基于事件”?)你能想到更好的方法吗?一些 linux 脚本代码片段将是完美的,因为那不是我以前做过的事情