我在 Ubuntu 上设置了 libvirt/KVM,在关闭机器之前,我希望它尝试使用 ACPI 关机(virsh shutdown)关闭虚拟机,然后我希望它停止关机至少 60 秒,以便虚拟机有机会将所有内容同步到磁盘,这是我所拥有的:
pre-stop script
SHUTDOWN_LOG=/var/log/libvirt/qemu/shutdown_vms.log
for RUNNING_VM in `virsh list | grep -E running | awk -F" " '{ print $2 }'`
do
echo "Shutting down ${RUNNING_VM} on `date`" >> $SHUTDOWN_LOG
virsh shutdown ${RUNNING_VM}
done
echo -n "Waiting for VM's to shut down: " >> $SHUTDOWN_LOG
for I in `seq 1 10`
do
RUNNING=`virsh list | grep running | wc -l`
if [[ "$RUNNING" == "0" ]]
then
echo "done." >> $SHUTDOWN_LOG
exit 0
else
/bin/sleep 6 && echo -n " ${RUNNING} " >> $SHUTDOWN_LOG
fi
done
echo " Cleaning up..." >> $SHUTDOWN_LOG
end script
我遇到的问题是,由于某些奇怪的原因,它永远不会回显“完成”。即使虚拟机全部正确关闭,它仍会继续循环并因此停滞 60 秒,或者它似乎完全忽略睡眠,将总数写入$SHUTDOWN_LOG
并立即退出,无论如何在我的虚拟机同步到磁盘的过程中。
Shutting down FreeBSD-services on Mon Aug 22 02:07:42 MDT 2011
Shutting down FreeBSD-pgsql on Mon Aug 22 02:07:42 MDT 2011
Waiting for VM's to shut down: 1 [EOF]
日志输出就是...有没有更好的方法从 upstart 进行日志记录?
答案1
https://bugs.launchpad.net/ubuntu/lucid/+source/libvirt/+bug/350936最近已经修复,因此很快就会有更新的 libvirt。
答案2
不幸的是,你无法从新贵脚本中回显,最好的选择是你已经在做的,即创建你自己的日志。
如果您还想输出到 syslog,您可以在 upstart 中使用 logger 执行此操作(就像在 init.d 中一样),但到目前为止,Upstart 调试还相当困难。
您还可以set -x
在停止前脚本的开头添加,以通过默认的 upstart 日志通道(Ubuntu 中的 syslog)获取更多输出