zoukankan      html  css  js  c++  java
  • OpenStack源码系列---nova-conductor

    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,开启一个新的绿色线程去完成虚拟机创建任务。

  • 相关阅读:
    基础薄弱的反思
    最短路SPFA
    乌龟棋
    石子归并
    Linux学习2
    java 基础 数组
    java 基础 异常
    java 基础 接口
    java 基础 instance of
    solidity“abi.encode/abi.encodePacked”使用golang编码
  • 原文地址:https://www.cnblogs.com/woshiweige/p/4518433.html
Copyright © 2011-2022 走看看