【OpenStack】Nova中的rebuild和evacuate

本文详细介绍了OpenStack Nova中的rebuild和evacuate操作,包括概念解析、功能区别、实践示例。rebuild用于更换虚拟机操作系统,而evacuate则在主机宕机时用于迁移虚拟机确保高可用。两者在底层实现上相似,但应用场景不同,目前只支持active和stopped状态的虚拟机。
摘要由CSDN通过智能技术生成

声明:

本博客欢迎转发,但请保留原作者信息!

新浪微博:@孔令贤HW;

博客地址:http://blog.csdn.net/lynn_kong

内容系本人学习、研究和总结,如有雷同,实属荣幸!


更新记录:

2013.06.24  增加在实际环境中rebuild的操作示例

2013.06.26  后端卷启动的虚拟机,rebuild无效


版本:Grizzly 2013.06.15

hypervisor:KVM


1、概念

rebuild:xp系统的虚拟机用烦了,想换个linux的操作系统,就可以使用rebuild。

evacuate:虚拟机所在的host宕机了,可以使用evacuate将虚拟机在另外一个host上启起来,其实利用这个接口配合host监控工具,可以实现虚拟机的HA能力。

为什么要将这两个一起说呢,是因为在底层,这两个接口其实对应一个操作。


2、rebuild

引用一下官方的API文档说明:


底层的实现,其实就是在虚拟机所在的host上,将原来的虚拟机干掉,然后再根据新的镜像创建一个新的虚拟机,实现虚拟机系统盘的变更,而用户盘的数据是不变的(软件的安装和配置会丢失),虚拟机的网络信息也不变。API里的accessIPv4和accessIPv6参数,在使用Quantum的场景下,是无效的。


目前rebuild仅支持active和stopped状态的虚拟机。而且使用后端卷启动的虚拟机,rebuild之后系统盘不会发生变化,见后面的实验部分。


3、evacuate

引用官方的API文档说明:


该接口使用的前提是虚拟机所在的host宕机。

参数onSharedStorage是让使用者指明,计算节点是否使用共享存储。其实在计算节点是有能力判断是否使用共享存储的(并且计算节点也确实会再进行判断),这里写在接口里,猜测应该是为了在API层做判断吧。

当使用共享存储时,才是真正意义上的HA,虚拟机的软件和数据不会丢失;否则,只有虚拟机的用户盘数据不会丢失,系统盘是全新的系统盘。


上面提到,rebuild和evacuate在底层的实现是一样的。其实想想也是,两个接口都需要重新创建虚拟机,唯一的区别是:

1、rebuild需要多做一步删除虚拟机的操作,而evacuate是直接创建新虚拟机。

2、rebuild使用的镜像是接口指定的新的镜像(可以与老镜像相同),而evacuate使用的是虚拟机原来的镜像。


再次引用下wiki上的evacuate流程图:



但evacuate也有一些不足,比如如果支持系统自动选择主机,用户体验可能会更好;还有,同rebuild一样,目前evacuate仅支持active和stopped状态的虚拟机,其他状态(paused,suspended等)的虚拟机是不支持的,这也就意味着其他状态的虚拟机遇到host故障的时候是无法恢复的。

顺带说一句,目前只有libvirt driver支持rebuild和evacuate。


4、实践

4.1、rebuild

步骤如下:

1、先使用keypaire创建cirros虚拟机,关联floatingip,创建成功后,ssh登录,操作正常。

root@controller231:~# nova show rebuild-test2
+-------------------------------------+----------------------------------------------------------+
| Property                            | Value                                                    |
+-------------------------------------+--------------------------------------------
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值