在 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 实例中查找临时实例存储卷

使用浏览器:

1.     连接到您的 Windows 实例

2.     打开浏览器并连接到:

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 实例,请参阅相关开发工具包文档,了解如何覆盖从设备到实例存储卷的映射。

这篇文章对您有帮助吗?


您是否需要账单或技术支持?