小木木 发表于 2015-10-13 13:23:33

CloudStack源码阅读与问题解决----SSVM启动条件

        在CloudStack建立zone的时候,经常遇到SSVM不启动,或者根本就没有SSVM的情况,分析CloudStack日志,会发现有“Zone 1 is not ready to launch secondary storage VM yet”打印,意思是zone还未准备好启动SSVM。
  通过查询CloudStack源代码,发现启动SSVM前有如下检查:

      获取Zone里的template。
        select a.* from vm_template a, host h where h.type = 'Routing' and h.data_center_id = 1 and a.type = 'System' and a.hypervisor_type = h.hypervisor_typelimit 1;   
        如果没有获取到,会打印如下警告:
        Warn: Zone host is ready, but secondary storage vm template3 is not ready on secondary storage: 1
        解决办法:检查system template是否已经下载完成(注意,要下载自己环境的hypervisor的system template)。

      获取zone的二级存储。
      select * from host where type = 'SecondaryStorage' and data_center_id = 1;# host id is 3
        如果没有获取到,会打印如下警告:
        Warn: No secondary storage available in zone 1, wait until it is ready to launch secondary storage vm
        解决办法:为zone 1建立secondary storage pool。
  

        获取template和host的关联。
      select * from template_host_ref where host_id = 3 and template_id = 1 and download_state = 'DOWNLOADED'; # host id and template id is query by before.
        如果没有获取到,会打印如下警告:
        Warn: Zone host is ready, but secondary storage vm template3 is not ready on secondary storage: 1
      如果secondary storage是NFS,可以通过mount来检查secondary storage是否能够正常工作,如果secondary storage没有问题,则只能等待CloudStack自动关联上。

      获得host的主存储。
      SELECT p.data_center_id,count(ph.host_id) countFROM storage_pool p, storage_pool_host_ref ph WHERE p.id = ph.pool_id AND p.data_center_id = 1 GROUP by p.data_center_id;
      主存储数量需要大于0,如果等于0,会打印如下警告:
        Warn: Primary storage is not ready, wait until it is ready to launch secondary storage vm
  

  没有问题后,CS会打印:Zone1 is ready to launch secondary storage VM。 CS将会启动 start secondary storage VM工作。
  

  
        CloudStack环境如何推到重来
CloudStack如何进行RDP(远程桌面)访问,如何登陆系统虚拟机
        CloudStack创建主存储失败(SR已经被使用),删除SR后成功
        CloudStack安装及使用过程中的几个常见问题
  

         版权声明:本文为博主原创文章,未经博主允许不得转载。
页: [1]
查看完整版本: CloudStack源码阅读与问题解决----SSVM启动条件