upstart 停止前脚本

upstart 停止前脚本

我在 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)获取更多输出

相关内容