您的位置:首页 > 其它

create instance 生成创建虚拟机从nova到调用libvirt流程(pycharm debug):

2016-02-29 00:00 495 查看
感谢朋友支持本博客,欢迎共同探讨交流,由于能力和时间有限,错误之处在所难免,欢迎指正!
如有转载,请保留源作者博客信息。

Better Me的博客blog.csdn.net/tantexian

如需交流,欢迎大家博客留言。
1、nova底层api创建虚拟机的route入口:



2、页面或者命令创建一个虚拟机,则会debug自动断电到pycharm代码:



3、调用compute的API接口代码(debug模式下可以看到compute_api对象为:nova.compute.api.API直接找到对应代码即可):

也可以使用debugF5跟踪: (eclipse模式的step into快捷键)



4、



在rv函数继续F5



跟踪到nova.compute.api.API的create函数:

















上述代码表示cast将消息发给消息队列。接下来消息队列收到消息会执行conductor的manager里面代码:

根据build_instances。找到对应的函数:



在此处加上断点,重启服务:







接下来发送到消息队列调用manager代码(cctxt.cast函数中ctxt参数的remote_address:表示将要发送消息动作到主机158执行代码):



走调度算法(详细分析请参考后续nova-scheduler调度算法详解):















































生成实例结束。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: