nova-conductor启动的也是一个rpc server,代码框架和nova-compute类似,所以我也懒得再详细分析一遍服务启动的过程。nova-api那篇文章的最后我说“cctxt.cast将请求发送到消息队列”,可是发送到哪个队列呢,哪个模块又来接收这个消息呢?我也看了网上的一些源码分析文章,可能是源代码版本不一样,感觉和我看的Juno版本的流程对不上,而这里有一篇文章Data flow of openstack request,正好和我看Juno版代码了解的流程一致。
比如创建虚拟机请求,nova-api最后是将消息发送到了nova-conductor。和nova-compute有一个ComputeManager类似,nova-conductor也有一个ConductorManager,暴露一些方法共客户端调用。在nova-api那篇文章中,发送消息的代码是:cctxt.cast(context, 'build_instances', **kw)。nova-conductor接收到消息后会调用相应的方法build_instances,在nova/conductor/manager.py文件中,有如下代码:
其中hosts = self.scheduler_client.select_destinations调用了nova-scheduler的rpc方法,获取调度之后选择的用于创
建虚拟机的nova-compute节点,然后self.compute_rpcapi.build_and_run_instance将消息发送给选中的nova-
compute节点。在nova/compute/manager.py文件中,我们看到了build_and_run_instance函数,如下图:
build_and_run_instance接着调用utils.spawn_n,开启一个新的绿色线程去完成虚拟机创建任务。