亚马逊AWS官方博客

使用 VM import 将 Azure 虚拟机迁移至 AWS 平台

通常我们做虚拟化,需要先做P2V然后将镜像导入到虚拟机中。而P2V后需要根据虚拟化层所支持的镜像类型做镜像格式的转换。在云平台间的虚拟机迁移,原理是差不多,可以看作是不同的虚拟化平台的迁移。这里我以Azure的VM虚拟机(ARM资源管理模式)迁移到AWS的EC2虚拟机为例:

(如果你使用的是早期的经典模式虚拟机Classic Model VM,请将经典模式转为资源管理模式ARM VM)本篇Blog使用VM Import/Export 可以让您轻松将虚拟机映像从现有环境导入到 Amazon EC2 实例中。

大致步骤与要把大象放到冰箱里总共分几步差不多:

  1. 将Azure的VM的镜像导出VHD
  2. 将Azure的VM镜像上传到对象存储
  3. 将VHD镜像转换为AMI并通过AMI启动EC2

一:创建Azure VHD镜像:

  1. 登录到 Azure 门户
  2. 首先在左测工具栏选择需要迁移的“虚拟机”。
  3. 在“虚拟机”边栏选项卡中进入设置中的“磁盘”。
  4. 然后在上方工具栏选择“创建快照”
  5. 输入快照的名称 。
  6. 选择现有的资源组,或键入新资源组的名称。
  7. 对于源磁盘,选择要获取其快照的托管磁盘。
  8. 选择用于存储快照的“帐户类型”。 使用Standard HDD,除非需要将其存储在高性能 SSD 上。
  9. 单击创建。

 

  • 选择需要迁移的虚拟机:

  • 导出VHD文件,创建快照导出(不需要停机,完整只读副本)

下载镜像并上传到S3对象存储:直接将镜像用EC2下载并上传到AWS的S3对象存储上。

需要本地安装windows AWS cli的工具,该工具可以通过命令将镜像文件上传到S3上。安装方法:

https://docs.thinkwithwp.com/zh_cn/cli/latest/userguide/install-windows.html

PS:如果你已经拥有一台安装了aws cli的AWS EC2 windows server可以直接运行命令。

 

将镜像copy到S3上:

$ aws s3 cp <source> <target> [--options]

注释:aws s3 cp 本地镜像存储的路径 S3://桶的路径
S3命令可以参考:https://docs.amazonaws.cn/cli/latest/userguide/cli-services-s3-commands.html

二:使用vmimport 工具来实现VHD镜像文件导入与AMI的转换:

1.创建一个角色vmimport并附件策略如下:


附加策略:

{

    "Version": "2012-10-17",

    "Statement": [

        {

            "Effect": "Allow",

            "Action": [

                "s3:GetBucketLocation",

                "s3:GetObject",

                "s3:ListBucket"

            ],

            "Resource": [

                "arn:aws-cn:s3:::vmwimport",

                "arn:aws-cn:s3:::vmwimport/*"

            ]

        },

        {

            "Effect": "Allow",

            "Action": [

                "ec2:ModifySnapshotAttribute",

                "ec2:CopySnapshot",

                "ec2:RegisterImage",

                "ec2:Describe*"

            ],

            "Resource": "*"

        }

    ]

}

 

2.编辑信任关系:

 

信任关系的策略如下:

 

{

  "Version": "2012-10-17",

  "Statement": [

    {

      "Effect": "Allow",

      "Principal": {

        "Service": "vmie.amazonaws.com"

      },

      "Action": "sts:AssumeRole",

      "Condition": {

        "StringEquals": {

          "sts:Externalid": "vmimport"

        }

      }

    }

  ]

}

3.导入VHD  AWS CLI运行命令:

aws ec2 import-image --cli-input-json "{  \"Description\": \"WinServer2008R2\", \"DiskContainers\": [ { \"Description\": \"First CLI task\", \"UserBucket\": { \"S3Bucket\": \"vmwimport\", \"S3Key\" : \"abcd\" } } ]}”

注释:

S3Bucket:是S3 bucket桶的名字

S3Key:是S3 bucket对象的名字

Progress:是进度

StatusMessage:是状态,分别经历 Pending——Converting——Uploading——Booting——Booted
这里我只截图3个状态:

 

 

 

 

 

4.我的AMI(AWS虚拟机镜像)

 

在EC2中AMI找到我们刚刚转换成功的AMI,并利用该AMI启用一台EC2.

 

回顾一下instance的生命周期,当EC2的状态是Running的时候,我们就登录进去:

 

这里需要注意的是登录的用户名与密码是你在Azure的VM中的系统用户名与密码信息。

 

总结:

本篇以Azure导入映像到AWS为例,其他平台迁移大同小异,因为VM Import/Export 支持的映像类型很多,比如:OVA,VHD/VHDX,VMDK,RAW。

VM Import/Export 可以让您轻松将虚拟机映像从现有环境导入到 Amazon EC2 实例中,然后再将导出回本地环境。它允许您将用于满足 IT 安全、配置管理和合规要求的虚拟机纳入 Amazon EC2 中作为随时可用的实例,从而充分利用其中的现有投资。您还可以将导入的实例导出回本地虚拟化基础设施,从而部署跨 IT 基础设施的工作负载。

除了 Amazon EC2 和 Amazon S3 的标准使用费外,VM Import/Export 无需其他任何费用。

 

参考链接:

https://docs.thinkwithwp.com/zh_cn/vm-import/latest/userguide/what-is-vmimport.html

 

本篇作者

李强

AWS解决方案架构师,负责基于AWS的云计算方案架构的咨询和设计,同时致力于AWS云服务在国内的应用和推广,在物联网和微软的技术栈有着广泛的设计和实践经验。在加入AWS之前,曾在东芝中国负责系统开发和运维工作,在微软中国负责中小企业的技术咨询和方案设计工作。