是否可以为Windows EC2实例创建EBS AMI?

我们在EC2中运行 Windows服务器(EBS支持).我们为数据备份定期创建快照.我想从其中一个快照创建一个新的EC2实例.

是的,我意识到这与拉动电源和打开机器是一样的,但我想测试数据在快照中的可靠性以便进行恢复.

我尝试使用Web控制台,命令行工具和ruby sdk从我们的Windows启动驱动器(EBS)的快照创建AMI映像 – 它们都创建了一个AMI,将平台显示Linux而不是Windows和半虚拟化虚拟化hvm.从这个AMI创建的新EC2实例无法上线,我认为它崩溃是因为它在错误的虚拟化平台上运行.

在我所做的所有谷歌搜索中,我只遇到过Linux指令,或者从实例支持的EC2实例制作Windows EBS的说明 – 不是EBS支持的实例或快照.

背景

Launching an Instance from a Snapshot不适用于Windows AMI(因为您有meanwhile discovered yourself):

Important

Registering a snapshot works only for Linux/UNIX AMIs;
although you can register a snapshot to create a Windows AMI,the AMI
isn’t launchable.
[emphasis mine]

替代

虽然未指定,但应该知道如Creating an Image from a Running Instance所述简单克隆Amazon EBS-Backed Instance的可能性 – 当通过AWS管理控制台执行此操作时,EC2会尝试在创建映像之前干净地关闭实例,然后重新启动实例.这显然是首选,但是,如果需要,可以通过命令行避免:

If you prefer the instance not be rebooted,you can use the Amazon EC2
command line tools to create the image […]. The 07004 command has a –no-reboot option.

上面提到的替代方法显然无助于从指定的其中一个快照创建一个新的EC2实例 – 无论如何都要注意一个有用的解决方案,请参阅移动到Eric Hammond的文章Move a Running EBS Boot Instance to New Hardware on Amazon EC2的新实例(其中有一个不同的用例,但无论如何适用)并归结为您的情况下的这些步骤:

>使用与原始实例相同的启动参数创建新实例.
>等待新实例运行,然后停止(不终止)它.
>从新实例中分离EBS启动卷并删除此分离卷,因为不再需要它.
>从快照创建新卷并将其附加到新实例.
>重新启动新实例,该实例现在将使用从快照创建的卷启动.

Colin Percival已经使用这种技术来运行FreeBSD on EC2 via defenestration以及btw. (其中包括对虚拟化问题的一些提示):

EC2 Windows instances,on the other hand,are launched in HVM (Hardware Virtual Machine) mode — which FreeBSD supports very well. If we can somehow trick EC2 into launching FreeBSD the same way as it launches Windows,we can run FreeBSD on a wide range of instance types. How can we trick EC2? Take advantage of the fact that Elastic Block Store disks can be detached from EC2 instances and reattached to different instances,and replace the boot disk of a “Windows” instance with a disk containing FreeBSD.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Windows注册表操作基础代码 Windows下对注册表进行操作使用的一段基础代码Reg.h:#pragmaonce#include<assert.h>#include<windows.h>classReg{HKEYhkey;public:voidopen(HKEYroot
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的内容,在Windows环境下的黑客必须熟练掌握底层API编程。为了使读者对黑客常用的Windows API有个更全面的了解以及方便日后使用API方法的查询,特将这些常用的API按照7大分类进行整理如下,希望对大家的学习有所帮助。一
一个简单的Windows Socket可复用框架说起网络编程,无非是建立连接,发送数据,接收数据,关闭连接。曾经学习网络编程的时候用Java写了一些小的聊天程序,Java对网络接口函数的封装还是很简单实用的,但是在Windows下网络编程使用的Socket就显得稍微有点繁琐。这里介绍一个自己封装的一
Windows文件操作基础代码 Windows下对文件进行操作使用的一段基础代码File.h,首先是File类定义:#pragmaonce#include<Windows.h>#include<assert.h>classFile{HANDLEhFile;//文件句柄publ
Winpcap基础代码 使用Winpcap进行网络数据的截获和发送都需要的一段代码:#include<PCAP.H>#pragmacomment(lib,"wpcap.lib")//#pragmacomment(lib,"ws2_32.lib")#
使用vbs脚本进行批量编码转换 最近需要使用SourceInsight查看分析在Linux系统下开发的项目代码,我们知道Linux系统中文本文件默认编码格式是UTF-8,而Windows中文系统中的默认编码格式是Gb2312。系统内的编码格式有所区别倒无伤大雅,关键的是SourceInsigh...
缓冲区溢出攻击缓冲区溢出(Buffer Overflow)是计算机安全领域内既经典而又古老的话题。随着计算机系统安全性的加强,传统的缓冲区溢出攻击方式可能变得不再奏效,相应的介绍缓冲区溢出原理的资料也变得“大众化”起来。其中看雪的《0day安全:软件漏洞分析技术》一书将缓冲区溢出攻击的原理阐述得简洁
Windows字符集的统一与转换一、字符集的历史渊源在Windows编程时经常会遇到编码转换的问题,一直以来让刚接触的人摸不着头脑。其实只要弄清Win32程序使用的字符编码方式就清楚了,图1展示了一个Win32控制台项目的属性中的字符集选项。这里有两个不同的字符集:一个是Unicode字符集,另一个
远程线程注入引出的问题一、远程线程注入基本原理远程线程注入——相信对Windows底层编程和系统安全熟悉的人并不陌生,其主要核心在于一个Windows API函数CreateRemoteThread,通过它可以在另外一个进程中注入一个线程并执行。在提供便利的同时,正是因为如此,使得系统内部出现了安全
windows系统启动项怎么打开
win10系统文件夹的只读属性去不掉怎么办
windows.old可以删掉吗?
windows的网络功能主要通过什么来实现?
win10系统以太网不见了怎么办
win10安装cad缺少net组件怎么办
win10系统鼠标移动方向相反怎么办
如何ping局域网内所有IP
windows10的系统保留分区有什么用
win10系统无法删除账户怎么办
win10系统音频服务未响应怎么办