我有一个运行磁盘快照的命令(在 EC2 上,冻结 XFS 磁盘并运行 EBS 快照命令),该命令设置为作为 cron 作业定期运行。理想情况下,如果在计划运行任务时磁盘被大量使用,我希望能够将命令延迟一段时间。
我担心使用 nice/ionice 可能不会产生适当的效果,因为我希望脚本在运行时以高优先级运行(即等待一段时间,然后快速完成)。
谢谢。
更新:
这就是我最终的结果。它检查 /proc/diskstats 并在当前 IO 活动达到 0 或我们超时时运行我的作业。当我查看我们的服务器在生产中实际获得什么样的 IO 活动时,我可能不得不对此进行调整:
#!/bin/bash
DEVICE=sdf
# we want to make a snapshot when IO in progresses reaches this:
LOW_THRESHOLD=0
TIMER=0
MAX_SEC_DELAY=120
# Get the number of IO operations in progress:
ioInProgress(){
grep $DEVICE /proc/diskstats | awk '{print $12}'
}
# Wait for a good time to run snapshot, else timeout:
while [[ $TIMER -lt $MAX_SEC_DELAY && $(ioInProgress) -gt $LOW_THRESHOLD ]]; do
TIMER=`expr $TIMER + 1`
sleep 0.5
done
# Recording delay required:
echo $TIMER
echo "Executing snapshot"
run-the-snapshot
你可以看看批处理命令也许它会满足你的需要。
man batch
了解更多详情(它是 at 子系统的一部分)我在这里找到了一个 perl 脚本http://www.skolnick.org/cgi-bin/list.pl?file=serverload.pl
这应该做你需要的。
您可能可以使用解析正常运行时间的简单 shell 脚本来实现这一点,并且只有在平均负载降低到某个值时才执行。
请注意,如果您的服务器一直很忙,并且进程失控,那么您的 cronjobs 将永远不会执行!
如果您有内存,也许更好的主意是以最低的操作系统优先级运行您的 cron 作业,因此它们只会消耗备用资源。
如何编写一个小轮询/守护程序脚本,从您计划的时间开始,检查 iostat (vmstat) 是否有低磁盘活动,并继续每 5 分钟检查一次,直到磁盘活动低于/低于预设阈值或一段时间有过去了,先到先得?