vmware迁移到openstack的一些坑
前言
主要有三个坑:
- 一是如果原先虚拟机没有安装virtio驱动,要设置设备驱动为ide,
- 二是cinder要配置glance_api_version的值为v2,上传的镜像需要是raw格式
- 三是迁移前后最好保持ip和主机名不变,这样对业务的影响最小
基础信息
给我们以下文件:
anquanpingtai-win2008r2-10.100.100.110.ova
解压后得到:
anquanpingtai-win2008r2_10.100.100.110-disk1.vmdk
anquanpingtai-win2008r2_10.100.100.110-disk2.vmdk
anquanpingtai-win2008r2 10.100.100.110.mf
anquanpingtai-win2008r2 10.100.100.110.ovf
我们使用 anquanpingtai-win2008r2作为主机名,10.100.100.110
迁移步骤
1. 查看镜像大小
查看vmdk镜像的信息,镜像1和镜像2的虚拟大小分饱是是100Gb,400Gb
[root@ha01-mon02-osd01 ~]# qemu-img info anquanpingtai-win2008r2_10.100.100.110-disk1.vmdk
image: anquanpingtai-win2008r2_110.100.100.110-disk1.vmdk
file format: vmdk
virtual size: 100G (107374182400 bytes)
disk size: 14G
cluster_size: 65536
Format specific information:
cid: 4099282801
parent cid: 4294967295
create type: streamOptimized
extents:
[0]:
compressed: true
virtual size: 107374182400
filename: anquanpingtai-win2008r2_10.100.100.110-disk1.vmdk
cluster size: 65536
format:
2. 将镜像上传到openstack
虽然openstack支持vmdk格式的镜像,但是ceph只支持raw格式的虚拟磁盘,所以我们要提前convert将镜像转换成raw格式再上传,节约时间。
qemu-img convert -f vmdk -O raw ./anquanpingtai-win2008r2_10.100.100.110-disk1.vmdk ./anquanpingtai_disk1
qemu-img convert -f vmdk -O raw ./anquanpingtai-win2008r2_10.100.100.110-disk2.vmdk ./anquanpingtai_disk2
glance image-create --name anquanpingtai_disk1 --disk-format "raw" --container-format 'bare' --progress --file ./anquanpingtai_disk1 --min-disk 100
glance image-create --name anquanpingtai_disk2 --disk-format "raw" --container-format 'bare' --progress --file ./anquanpingtai_disk2 --min-disk 400
因为vmware过来的镜像没有安装virtio驱动,所以我们要设置镜像的磁盘驱动为ide,网卡驱动为e1000,这样子虚拟机的性能差一些,所以如果有条件的话,最好在迁移之前把虚拟机virtio的网卡和磁盘驱动安装好
openstack image set --property hw_disk_bus=ide --property hw_vif_model=e1000 anquanpingtai_disk1
openstack image set --property hw_disk_bus=ide --property hw_vif_model=e1000 anquanpingtai_disk2
3. 以镜像为源,创建云硬盘
如果镜像的磁盘格式是raw,且cinder访问glance使用的api版本是v2,以镜像为源创建云硬盘的时候,cinder支持直接rbd clone镜像文件来复制镜像文件,创建云硬盘。否则,cinder需要把镜像下载到本地文件系统,转换成raw格式,再上传到ceph中,当镜像文件很大的时候,这个过程常常因为超时而失败。
所以我们需要修改cinder.conf服务的glance_api_version为v2,然后重启cinder-volume服务。
使用这两上一步个镜像创建云硬盘, 大小为100G和400G, id分别记作VOLUME1_ID, VOLUME2_ID
4. 创建迁移用网络
迁移前后最好保持虚拟机的ip不变,这样可以避免很多未知问题
按照科技网给出的信息,服务器的ip是10.100.100.110,所以我们需要创建一个网络10.100.100.0/24,由于我们不计划通过这个网络来访问外网,所以这个网络可以是任何类型,vlan,vxlan,flat都可以,只要里面包含这两个ip就可以,所以可以直接在界面创建,这里不再给出命令,将创建的网络id记作$MIG_NET_ID
5. 创建虚拟机
假设我们已经完成上述步骤,用以下命令创建虚拟机,并指定ip
nova boot --flavor 4 --block-device source=volume,dest=volume,id=$VOLUME1_ID ,bus=ide,bootindex=0,shutdown=preserve --nic net-id=$MIG_NET_ID,v4-fixed-ip=10.100.100.110 anquanpingtai-win2008r2
![enter description here][1]
6. 绑定云硬盘
由于ide驱动不支持热插拔,所以我们要将虚拟机关机,然后将之前创建的400G大小的硬盘2,再重新开机, 在界面上操作就可以,这里不给出命令
至此,服务器状态的恢复就完成了
7. 绑定浮动ip并连接网络
给这个虚拟机绑定一个浮动ip,然后联系网络部同事,将这个浮动ip的80端口映射到公网ip上,即可。
6. 绑定云硬盘
由于ide驱动不支持热插拔,所以我们要将虚拟机关机,然后将之前创建的400G大小的硬盘2,再重新开机, 在界面上操作就可以,这里不给出命令
至此,服务器状态的恢复就完成了
vmware迁移到openstack的一些坑的更多相关文章
- OpenStack 之vmware机器迁移到openstack集群
原理 openstack本身是支持使用vmware格式的镜像的,但是是需要我们我们在/etc/nova/nova.conf的配置文件中指定该计算节点使用vmware的驱动 1 2 3 4 5 6 7 ...
- virt-v2v命令将ESXI 虚机迁移到OpenStack中
一简介: virt-v2v是将外部的虚拟化平台上的虚拟机转化到可以运行的KVM平台上.它可以读取在VMware.Xen运行Hyper-V和其他虚拟机管理程序上的Windows和Linux的虚拟机,并将 ...
- v2v-VMware/VSphere中虚机离线迁移至openstack平台
先决条件 exsi到openstack的迁移,分为两种,一种是静态迁移,另一种是在线迁移. 静态迁移(offline migration)也叫做常规迁移,离线迁移.在迁移之前将虚拟机暂停,同时拷贝虚拟 ...
- 从Oracle迁移到MySQL的各种坑及自救方案
当企业内部使用的数据库种类繁杂时,或者有需求更换数据库种类时,都可能会做很多数据迁移的工作.有些迁移很简单,有些迁移可能就会很复杂,大家有没有考虑过为了顺利完成复杂的数据库迁移任务,都需要考虑并解决哪 ...
- Vmware迁移以后eth0消失,无法上网
一个再普通不过的大神帮助小菜做虚拟机镜像的事情: 小张:帮我做个Vmware下的Ubuntu镜像吧,大神. 小黄:好啊,等我一下,下午发给你. 经过一番操作,小黄顺利的做出了一个虚拟机操作系统 小黄: ...
- 从 ASP.NET Core 2.1 迁移到 2.2 踩坑总结
官方迁移文档:https://docs.microsoft.com/zh-cn/aspnet/core/migration/21-to-22?view=aspnetcore-2.2&tabs= ...
- migration vmware vms to openstack kvm 修改vmware windows scsi to ide
- Openstack部署踩坑
第一周: 使用kola部署Openstack,vip_address有问题,双网上也不行,就是部署不了,但all-in-one却可以,可是节点不会加. 第二周: 使用Packstack部署Openst ...
- 安装VMware Tools的步骤和那些坑
背景环境:VMware workstation 12.5+Ubuntu16.04 首先VMware Tools在ubuntu中是及其不稳定的,也就是说,当你点击菜单栏中的install vmware ...
随机推荐
- SpringCloud的服务消费者 (一):(rest+ribbon)访问注册的微服务
采用Ribbon或Feign方式访问注册到EurekaServer中的微服务.1.Ribbon实现了客户端负载均衡,Feign底层调用Ribbon2.注册在EurekaServer中的微服务api,不 ...
- 英语词汇(5)followed by / sung by / written by
Sung by 演唱者; [例句]In the recording I have today, it is sung by a male alto.我今天带的唱片是由一位男高音歌手唱的. follow ...
- maven快速下载jar镜像
<!--国内镜像--><mirror> <id>CN</id> <name>OSChina Central</name> ...
- Ecplise 配置本地 https 测试
今天做项目,需要关联Office 365.为了实现Office365的用户邮件信息与项目的实时同步,需要建立webhook订阅. Office 365 API 连接 https://graph.mi ...
- Spring Cloud学习笔记-009
API网关服务:Spring Cloud Zuul API网关是一个更为智能的应用服务器,它的定义类似于面向对象设计模式中的Façade模式,它的存在就像是整个微服务架构系统的门面一样,所有的外部客户 ...
- 【转】Impala导出查询结果到文件
[转载出处]http://blog.csdn.net/jobschen/article/details/68942574 想用impala-shell 命令行中将查询的结果导出到本地文件,想当然的以为 ...
- Java操作属性文件与国际化
在前面讲到的java类集中的Hashtable中,有一个子类Properties,此类定义如下: public class Properties extends Hashtable<Object ...
- 最快的3x3中值模糊
10.1国庆后,知名博主:laviewpbt http://www.cnblogs.com/Imageshop/ 发起了一个优化3x3中值模糊的小活动. 俺也参加其中,今天博主laviewpbt ...
- [SDOI 2015]序列统计
Description 题库链接 给出集合 \(S\) ,元素都是小于 \(M\) 的非负整数.问能够生成出多少个长度为 \(N\) 的数列 \(A\) ,数列中的每个数都属于集合 \(S\) ,并且 ...
- [CQOI 2010]扑克牌
Description 你有n种牌,第i种牌的数目为ci.另外有一种特殊的 牌:joker,它的数目是m.你可以用每种牌各一张来组成一套牌,也可以用一张joker和除了某一种牌以外的其他牌各一张组成1 ...