Amazon A EC2 uto Scaling 是如何使用的 IAM - Amazon A EC2 uto Scaling

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

Amazon A EC2 uto Scaling 是如何使用的 IAM

在使用IAM管理对 Amazon A EC2 uto Scaling 的访问权限之前,请先了解哪些IAM功能可用于 Amazon A EC2 uto Scaling。

IAM你可以在 Amazon A EC2 uto Scaling 中使用的功能
IAM特征 Amazon A EC2 uto Scaling 支持

基于身份的策略

基于资源的策略

策略操作

策略资源

策略条件键(特定于服务)

ACLs

不支持

ABAC(策略中的标签)

部分

临时凭证

服务角色

服务相关角色

要全面了解 Amazon A EC2 uto Scaling 和其他功能如何 AWS 服务 使用大多数IAM功能 AWS 服务 ,请在《IAM用户指南》IAM中查看如何使用这些功能。

Ama EC2 zon Auto Scaling 的基于身份的政策

支持基于身份的策略:

基于身份的策略是可以附加到身份(例如IAM用户、用户组或角色)的JSON权限策略文档。这些策略控制用户和角色可在何种条件下对哪些资源执行哪些操作。要了解如何创建基于身份的策略,请参阅IAM用户指南中的创建IAM策略

使用IAM基于身份的策略,您可以指定允许或拒绝的操作和资源,以及允许或拒绝操作的条件。您无法在基于身份的策略中指定主体,因为它适用于其附加的用户或角色。要了解可以在JSON策略中使用的所有元素,请参阅IAM用户指南中的IAMJSON策略元素参考

Amazon A EC2 uto Scaling 中基于资源的政策

支持基于资源的策略:

基于资源的JSON策略是您附加到资源的策略文档。基于资源的策略的示例包括IAM角色信任策略和 Amazon S3 存储桶策略。在支持基于资源的策略的服务中,服务管理员可以使用它们来控制对特定资源的访问。对于在其中附加策略的资源,策略定义指定主体可以对该资源执行哪些操作以及在什么条件下执行。您必须在基于资源的策略中指定主体。委托人可以包括账户、用户、角色、联合用户或 AWS 服务。

要启用跨账户访问权限,您可以将整个账户或另一个账户中的IAM实体指定为基于资源的策略中的委托人。将跨账户主体添加到基于资源的策略只是建立信任关系工作的一半而已。当委托人和资源处于不同位置时 AWS 账户,可信账户中的IAM管理员还必须向委托人实体(用户或角色)授予访问资源的权限。他们通过将基于身份的策略附加到实体以授予权限。但是,如果基于资源的策略向同一个账户中的主体授予访问权限,则不需要额外的基于身份的策略。有关更多信息,请参阅《IAM用户指南》IAM中的跨账户资源访问权限

Amazon A EC2 uto Scaling 的政策行动

支持策略操作:

管理员可以使用 AWS JSON策略来指定谁有权访问什么。也就是说,哪个主体 可以对什么资源执行操作,以及在什么条件下执行。

JSON策略Action元素描述了可用于在策略中允许或拒绝访问的操作。策略操作通常与关联的 AWS API操作同名。也有一些例外,例如没有匹配API操作的仅限权限的操作。还有一些操作需要在策略中执行多个操作。这些附加操作称为相关操作

在策略中包含操作以授予执行关联操作的权限。

要查看 Amazon A EC2 uto Scaling 操作列表,请参阅《服务授权参考》中的 Amazon A EC2 uto Scaling 定义的操作

Amazon A EC2 uto Scaling 中的策略操作在操作前使用以下前缀:

autoscaling

要在单个语句中指定多项操作,请使用逗号将它们隔开。

"Action": [ "autoscaling:action1", "autoscaling:action2" ]

您还可以使用通配符(*)指定多项操作。例如,要指定以单词 Describe 开头的所有操作,包括以下操作:

"Action": "autoscaling:Describe*"

Amazon A EC2 uto Scaling 的策略资源

支持策略资源:

管理员可以使用 AWS JSON策略来指定谁有权访问什么。也就是说,哪个主体 可以对什么资源执行操作,以及在什么条件下执行。

ResourceJSON策略元素指定要应用操作的一个或多个对象。语句必须包含 ResourceNotResource 元素。最佳做法是,使用资源的 Amazon 资源名称 (ARN) 指定资源。对于支持特定资源类型(称为资源级权限)的操作,您可以执行此操作。

对于不支持资源级权限的操作(如列出操作),请使用通配符 (*) 指示语句应用于所有资源。

"Resource": "*"

您可以使用ARNs识别该IAM策略适用的Auto Scaling组和启动配置。

Auto Scaling 组具有以下内容ARN。

"Resource": "arn:aws:autoscaling:region:account-id:autoScalingGroup:uuid:autoScalingGroupName/asg-name"

启动配置具有以下内容ARN。

"Resource": "arn:aws:autoscaling:region:account-id:launchConfiguration:uuid:launchConfigurationName/lc-name"

要使用CreateAutoScalingGroup操作指定 Auto Scaling 组,必须UUID使用通配符 (*) 替换,如以下示例所示。

"Resource": "arn:aws:autoscaling:region:account-id:autoScalingGroup:*:autoScalingGroupName/asg-name"

要使用CreateLaunchConfiguration操作指定启动配置,必须将替换为UUID通配符 (*),如下例所示。

"Resource": "arn:aws:autoscaling:region:account-id:launchConfiguration:*:launchConfigurationName/lc-name"

有关 Amazon A EC2 uto Scaling 资源类型及其类型的更多信息ARNs,请参阅《服务授权参考》中的 Amazon A EC2 uto Scaling 定义的资源。要了解您可以使用哪些操作来指定每种资源,请参阅 Amazon A EC2 uto Scaling 定义的操作。ARN

注意

有关用于控制 Auto Sc ARNs aling 组访问权限的IAM策略示例,请参阅控制可以删除哪些自动扩缩组

并非所有 Amazon A EC2 uto Scaling 操作都支持资源级权限。对于不支持资源级别权限的操作,您必须将通配符(*)作为资源。

以下 Amazon A EC2 uto Scaling 操作不支持资源级权限。

  • DescribeAccountLimits

  • DescribeAdjustmentTypes

  • DescribeAutoScalingGroups

  • DescribeAutoScalingInstances

  • DescribeAutoScalingNotificationTypes

  • DescribeInstanceRefreshes

  • DescribeLaunchConfigurations

  • DescribeLifecycleHooks

  • DescribeLifecycleHookTypes

  • DescribeLoadBalancers

  • DescribeLoadBalancerTargetGroups

  • DescribeMetricCollectionTypes

  • DescribeNotificationConfigurations

  • DescribePolicies

  • DescribeScalingActivities

  • DescribeScalingProcessTypes

  • DescribeScheduledActions

  • DescribeTags

  • DescribeTerminationPolicyTypes

  • DescribeWarmPool

Amazon A EC2 uto Scaling 的策略条件密钥

支持特定于服务的策略条件键:

管理员可以使用 AWS JSON策略来指定谁有权访问什么。也就是说,哪个主体可以对什么资源执行操作,以及在什么条件下执行。

Condition 元素(或 Condition )中,可以指定语句生效的条件。Condition 元素是可选的。您可以创建使用条件运算符(例如,等于或小于)的条件表达式,以使策略中的条件与请求中的值相匹配。

如果您在一个语句中指定多个 Condition 元素,或在单个 Condition 元素中指定多个键,则 AWS 使用逻辑 AND 运算评估它们。如果您为单个条件键指定多个值,则使用逻辑OR运算来 AWS 评估条件。在授予语句的权限之前必须满足所有的条件。

在指定条件时,您也可以使用占位符变量。例如,只有在资源上标有IAM用户的用户名时,您才能向IAM用户授予访问该资源的权限。有关更多信息,请参阅《IAM用户指南》中的IAM策略元素:变量和标签

AWS 支持全局条件密钥和特定于服务的条件密钥。要查看所有 AWS 全局条件键,请参阅《IAM用户指南》中的AWS 全局条件上下文密钥

Amazon A EC2 uto Scaling 支持以下条件键,这些条件键可用于控制对支持操作的访问权限和强制配置 Auto Scaling 群组:

  • autoscaling:InstanceTypes

  • autoscaling:LaunchConfigurationName

  • autoscaling:LaunchTemplateVersionSpecified

  • autoscaling:LoadBalancerNames

  • autoscaling:MaxSize

  • autoscaling:MinSize

  • autoscaling:ResourceTag/key-name: tag-value

  • autoscaling:TargetGroupARNs

  • autoscaling:VPCZoneIdentifiers

以下条件键特定于创建启动配置请求:

  • autoscaling:ImageId

  • autoscaling:InstanceType

  • autoscaling:MetadataHttpEndpoint

  • autoscaling:MetadataHttpPutResponseHopLimit

  • autoscaling:MetadataHttpTokens

  • autoscaling:SpotPrice

Amazon A EC2 uto Scaling 还支持以下全局条件密钥,您可以使用这些条件密钥根据请求中的标签或 Auto Scaling 组中存在的标签来定义权限。有关更多信息,请参阅 为 Auto Scaling 组和实例添加标签

  • aws:RequestTag/key-name: tag-value

  • aws:ResourceTag/key-name: tag-value

  • aws:TagKeys: [tag-key, ...]

要了解您可以将条件键与哪EC2些 Amazon Auto Scaling API 操作一起使用,请参阅《服务授权参考》中的 Amazon A EC2 uto Scaling 定义的操作。有关 Amazon A EC2 uto Scaling 条件键的更多信息,请参阅 Amazon A EC2 uto Scaling 的条件密钥

注意

有关使用条件键控制对支持操作的访问权限和强制配置 Auto Scaling 组的IAM策略示例,请参阅以下资源:

ACLs在 Amazon A EC2 uto Scaling 中

支持ACLs:

访问控制列表 (ACLs) 控制哪些委托人(账户成员、用户或角色)有权访问资源。ACLs与基于资源的策略类似,尽管它们不使用JSON策略文档格式。

ABAC使用 Amazon A EC2 uto Scaling

支持ABAC(策略中的标签):部分

基于属性的访问控制 (ABAC) 是一种基于属性定义权限的授权策略。在中 AWS,这些属性称为标签。您可以将标签附加到IAM实体(用户或角色)和许多 AWS 资源。为实体和资源添加标签是的第一步。ABAC然后,您可以设计ABAC策略,允许在委托人的标签与他们尝试访问的资源上的标签匹配时进行操作。

ABAC在快速增长的环境中很有用,也有助于解决策略管理变得繁琐的情况。

要基于标签控制访问,您需要使用 aws:ResourceTag/key-nameaws:RequestTag/key-nameaws:TagKeys 条件键在策略的条件元素中提供标签信息。

如果某个服务对于每种资源类型都支持所有这三个条件键,则对于该服务,该值为。如果某个服务仅对于部分资源类型支持所有这三个条件键,则该值为部分

有关的更多信息ABAC,请参阅什么是ABAC? 在《IAM用户指南》中。要查看包含设置步骤的教程ABAC,请参阅IAM用户指南中的使用基于属性的访问控制 (ABAC)

ABAC支持标签的资源是可能的,但并非所有资源都支持标签。启动配置和扩缩策略不支持标签,但自动扩缩组支持标签。

有关更多信息,请参阅 为 Auto Scaling 组和实例添加标签

在 Amazon A EC2 uto Scaling 中使用临时证书

支持临时凭证:

当你使用临时证书登录时,有些 AWS 服务 不起作用。有关其他信息,包括哪些 AWS 服务 适用于临时证书 AWS 服务 ,请参阅《IAM用户指南》IAM中的 “适用于临时证书”。

如果您使用除用户名和密码之外的任何方法登录,则 AWS Management Console 使用的是临时证书。例如,当您 AWS 使用公司的单点登录 (SSO) 链接进行访问时,该过程会自动创建临时证书。当您以用户身份登录控制台,然后切换角色时,您还会自动创建临时凭证。有关切换角色的更多信息,请参阅《IAM用户指南》中的切换到角色(控制台)

您可以使用 AWS CLI 或手动创建临时证书 AWS API。然后,您可以使用这些临时证书进行访问 AWS。 AWS 建议您动态生成临时证书,而不是使用长期访问密钥。有关更多信息,请参阅中的临时安全证书IAM

Amazon A EC2 uto Scaling 的服务角色

支持服务角色:

服务IAM角色是服务代替您执行操作的角色。IAM管理员可以在内部创建、修改和删除服务角色IAM。有关更多信息,请参阅《IAM用户指南》 AWS 服务中的创建角色以向委派权限

在创建通知亚马逊SNS主题或亚马逊SQS队列的生命周期挂钩时,必须指定一个角色以允许 Amazon A EC2 uto Scaling 代表您访问亚马逊SNS或亚马逊SQS。使用IAM控制台为生命周期挂钩设置服务角色。控制台可帮助您使用托管式策略创建一个具有足够权限集的角色。有关更多信息,请参阅使用 Amazon SNS 接收通知使用 Amazon SQS 接收通知

创建 Auto Scaling 组时,您可以选择传入服务角色,以允许 Amazon EC2 实例代表您访问其他 AWS 服务 实例。Amazon EC2 实例的服务角色(也称为启动模板或启动配置的 Amazon EC2 实例配置文件)是一种特殊类型的服务角色,在EC2实例启动时分配给 Auto Scaling 组中的每个实例。您可以使用IAM控制台和 AWS CLI 来创建或编辑此服务角色。有关更多信息,请参阅 在 Amazon EC2 实例上运行的应用程序的 IAM 角色

警告

更改服务角色的权限可能会中断 Amazon A EC2 uto Scaling 的功能。仅当 Amazon A EC2 uto Scaling 提供相关指导时才编辑服务角色。

Amazon A EC2 uto Scaling 的服务相关角色

支持服务相关角色:

服务相关角色是一种与服务相关联的 AWS 服务服务角色。服务可以代入代表您执行操作的角色。服务相关角色出现在您的中 AWS 账户 ,并且归服务所有。IAM管理员可以查看但不能编辑服务相关角色的权限。

有关创建或管理 Amazon A EC2 uto Scaling 服务相关角色的详细信息,请参阅Amazon EC2 Auto Scaling 的服务相关角色