DDR爱好者之家 Design By 杰米

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_type limit 1;   

        如果没有获取到,会打印如下警告:

        Warn: Zone host is ready, but secondary storage vm template  3 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 template  3 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) count  FROM 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会打印:Zone  1 is ready to launch secondary storage VM。 CS将会启动 start secondary storage VM工作。

         感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米