在 EC2 控制台中创建警报时为什么禁用“恢复此实例”选项?
上次更新时间:2018 年 12 月 12 日
我正在尝试在 Amazon Elastic Compute Cloud (Amazon EC2) 控制台中创建 Amazon CloudWatch 警报。我希望能够在我的 EC2 实例因底层硬件故障而受损时将其恢复,并在警报触发时发送通知。但是,在 Create Alarm(创建警报)页面上,“Take the action”(执行操作)下的“Recover this instance”(恢复此实例)选项显示为灰色(已禁用)。警报通知选项也被禁用。如何重新启用这些选项?
简短描述
如果 CloudWatch 确定 EC2 实例使用的是实例存储卷,则会禁用 Recover this instance(恢复此实例)选项。使用实例存储卷的 EC2 实例(包括使用实例存储卷的块储存设备映射启动的实例)不支持恢复操作。CloudWatch 读取与每个 EC2 实例关联的元数据,以确保在启用恢复操作之前它使用的不是实例存储卷。
注意:仅某些实例类型支持恢复操作。请确保您启动的是支持的实例类型。有关更多信息,请参阅恢复您的实例。EC2 恢复警报操作仅对 StatusCheckFailed_System 指标有效。
解决方法
注意:如果您在运行 AWS 命令行界面 (AWS CLI) 命令时遇到错误,请确保您运行的是最新版本的 AWS CLI。
在继续之前,请参阅创建停止、终止、重启或恢复实例的警报。确保您满足创建 CloudWatch 警报的所有先决条件。
在 EC2 Linux 实例中查找临时实例存储卷
1. 连接到您的 Linux 实例。
2. 使用以下命令检索实例元数据。
curl http://169.254.169.254/latest/meta-data/block-device-mapping/
3. 使用输出确定映射到实例的实例存储卷(名称以“ephemeral”开头)。例如,此输出中有两个实例存储卷(“ephemeral0”和“ephemeral2”):
[ec2-user ~]$ curl http://169.254.169.254/latest/meta-data/block-device-mapping/
ami
ephemeral0
ephemeral2
root
在 EC2 Windows 实例中查找临时实例存储卷
http://169.254.169.254/latest/meta-data/block-device-mapping/
3. 使用返回的信息确定映射到实例的实例存储卷(名称以“ephemeral”开头)。
使用 Windows PowerShell:
1. 在 PowerShell 中连接到您的 Windows 实例。
2. 运行以下命令:
PS C:\> Invoke-RestMethod -uri http://169.254.169.254/latest/meta-data/block-device-mapping/
3. 使用输出确定映射到实例的实例存储卷(名称以“ephemeral”开头)。例如,此输出中有一个实例存储卷(“ephemeral0”):
ami
ephemeral0
root
swap
有关更多信息,请参阅查看实例存储卷的实例块储存设备映射。
在用于 EC2 实例的 AMI 中查找临时实例存储卷
查看 EC2 实例的 Amazon 系统映像 (AMI) 的块储存设备映射。检查块储存设备实例存储卷的“Block Devices”(块存储设备)字段包含“=ephemeral#”,其中“#”是一个介于 0 至 23 之间的整数。
即使实例类型未正式支持实例存储卷,块储存设备映射也可能发生。当您使用下面的任意一种方法启动 EC2 实例(Windows 或 Linux)时,则可能会发生此操作:
- AWS CLI
- 软件开发工具包
- AWS CloudFormation 等服务
当您使用 Amazon EC2 控制台启动不支持实例存储卷的实例类型时,Amazon EC2 将会忽略已修改的块储存设备映射。
您可以使用 Amazon EC2 控制台或 AWS CLI 枚举 AMI 块储存设备映射中的 EBS 卷。
例如,下面的 describe-images 命令将会返回 AMI 的 BlockDeviceMapping:
aws ec2 describe-images --image-ids ami-xxxxxxxx
“VirtualName”以“ephemeral”开头的实例存储卷的示例输出:
aws ec2 describe-images --image-ids ami-11112222
"BlockDeviceMappings": [
{
"DeviceName": "/dev/xvda",
"Ebs": {
"DeleteOnTermination": true,
"SnapshotId": "snap- ",
"VolumeSize": 8,
"VolumeType": "gp2",
"Encrypted": false
}
},
{
"DeviceName": "/dev/sdb",
"VirtualName": "ep0hemeral0"
},
{
"DeviceName": "/dev/sdc",
"VirtualName": "ephemeral2"
}
],
移除或覆盖对 AMI 中实例存储卷的任何引用
在确认 EC2 实例使用实例存储卷之后,必须移除或覆盖对 AMI 中实例存储卷的任何引用。然后,您必须重新启动实例,因为无法在现有 EC2 实例中添加或移除实例存储卷。
使用下面的任意一种方法移除或覆盖对实例存储卷的引用:
- 从 AMI 中删除对实例存储卷的引用。然后,重新启动实例。
- 从 Amazon EC2 控制台启动 EC2 实例,以覆盖不支持实例卷存储的实例类型的 AMI。
- 从 AWS CLI 启动 EC2 实例,然后手动覆盖 AMI 中引用实例存储卷的每个设备。例如,假设您的设备“/dev/sdb”和“/dev/sdc”映射到实例存储卷,则使用 run-instances 命令启动 EC2 实例:
aws ec2 run-instances --image-id ami-11112222 --subnet-id subnet-11112222 --instance-type t2.medium --key-name my_key --associate-public-ip-address --block-device-mappings '[{"DeviceName": "/dev/sdb","NoDevice": ""},{"DeviceName": "/dev/sdc","NoDevice": ""}]'
- 对于 CloudFormation 启动的 EC2 实例,请创建 CloudFormation 模板来覆盖任何设备到实例存储卷的映射。例如:
{ "AWSTemplateFormatVersion": "2010-09-09", "Resources": { "I4EY8I": { "Type" : "AWS::EC2::Instance", "Properties": { "ImageId" : "ami-11112222", "InstanceType" : "t2.medium", "SubnetId" : "subnet-11112222", "KeyName" : "my_key", "BlockDeviceMappings" : [ { "DeviceName":"/dev/sdb", "NoDevice": {} }, { "DeviceName":"/dev/sdc", "NoDevice": {} } ] } } } }
- 对于使用软件开发工具包启动的 EC2 实例,请参阅相关开发工具包文档,了解如何覆盖从设备到实例存储卷的映射。