使用 Lambda 的服务相关角色 - Amazon Lambda
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

使用 Lambda 的服务相关角色

Lambda 使用 Amazon Identity and Access Management(IAM)服务相关角色。服务相关角色是一种独特类型的 IAM 角色,它与 Lambda 直接相关。服务相关角色由 Lambda 预定义,并包含该服务代表您调用其他 Amazon 服务所需的权限。

Lambda 定义其服务相关角色的权限,并且仅 Lambda 可以担任其角色。定义的权限包括信任策略和权限策略,以及不能附加到任何其他 IAM 实体的权限策略。

只有在首先删除相关资源后,您才能删除服务关联角色。这可以保护您的 Lambda 资源,因为您不会无意中删除对资源的访问权限。

有关支持服务相关角色的其他服务的信息,请参阅使用 IAM 的 Amazon 服务,并查找服务相关角色列中显示为的服务。选择和链接,查看该服务的服务关联角色文档。

Lambda 的服务相关角色权限

Lambda 使用名为 AWSServiceRoleForLambda 的服务相关角色。 服务相关角色信任以下服务代入该角色:

  • lambda.amazonaws.com

名为 AWSLambdaServiceRolePolicy 的角色权限策略允许 Lambda 对指定资源完成以下操作:

  • 操作:arn:aws:ec2:*:*:instance/* 上的 ec2:TerminateInstances,具有条件 ec2:ManagedResourceOperator = scaler.lambda.amazonaws.com

  • 操作:* 上的 ec2:DescribeInstanceStatusec2:DescribeInstances

您必须配置使用户、组或角色能够创建、编辑或删除服务相关角色的权限。有关更多信息,请参阅《IAM 用户指南》中的服务相关角色权限

有关托管策略更新,请参阅 Lambda 托管策略

为 Lambda 创建服务相关角色

您无需手动创建服务关联角色。当您在 Amazon Web Services 管理控制台、Amazon CLI 或 Amazon API 中创建 Lambda 容量提供程序时,Lambda 将为您创建服务相关角色。

如果您删除该服务关联角色,然后需要再次创建,您可以使用相同流程在账户中重新创建此角色。当您创建 Lambda 容量提供程序时,Lambda 将为您再次创建服务相关角色。

您还可以使用 IAM 控制台创建具有 AWSServiceRoleForLambda 使用案例的服务相关角色。在 Amazon CLI 或 Amazon API 中,使用 lambda.amazonaws.com 服务名称创建服务相关角色。有关更多信息,请参阅《IAM 用户指南》中的创建服务相关角色。如果您删除了此服务相关角色,可以使用同样的过程再次创建角色。

编辑 Lambda 的服务相关角色

Lambda 不允许编辑 AWSServiceRoleForLambda 服务相关角色。创建服务关联角色后,您将无法更改角色的名称,因为可能有多种实体引用该角色。但是可以使用 IAM 编辑角色描述。有关更多信息,请参阅《IAM 用户指南》中的编辑服务关联角色

删除 Lambda 的服务相关角色

如果不再需要使用某个需要服务关联角色的功能或服务,我们建议您删除该角色。这样就没有未被主动监控或维护的未使用实体。但是,必须先清除服务相关角色的资源,然后才能手动删除它。

注意

如果在您试图删除资源时 Lambda 服务正在使用该角色,则删除操作可能会失败。如果发生这种情况,请等待几分钟后重试。

删除 AWSServiceRoleForLambda 使用的 Lambda 资源
  1. 从您的账户中移除所有 Lambda 容量提供程序。您可以使用 Lambda 控制台、CLI 或 API 执行此操作。

  2. 尝试删除服务相关角色之前,请确认您的账户中没有剩下 Lambda 容量提供程序。

使用 IAM 手动删除服务关联角色

使用 IAM 控制台、Amazon CLI 或 Amazon API 删除 AWSServiceRoleForLambda 服务相关角色。有关更多信息,请参阅《IAM 用户指南》中的删除服务相关角色

Lambda 服务相关角色的受支持区域

Lambda 并非在提供该服务的每个区域中都支持使用服务相关角色。在以下区域中支持 AWSServiceRoleForLambda。

区域名称 区域标识 Lambda 中的支持
美国东部(弗吉尼亚州北部) us-east-1
美国东部(俄亥俄州) us-east-2
美国西部(北加利福尼亚) us-west-1
美国西部(俄勒冈州) us-west-2
非洲(开普敦) af-south-1
亚太地区(香港) ap-east-1
亚太地区(雅加达) ap-southeast-3
亚太地区(曼谷) ap-southeast-7
亚太地区(孟买) ap-south-1
亚太地区(大阪) ap-northeast-3
Asia Pacific (Seoul) ap-northeast-2
亚太地区(新加坡) ap-southeast-1
亚太地区(悉尼) ap-southeast-2
亚太地区(东京) ap-northeast-1
加拿大(中部) ca-central-1
欧洲地区(法兰克福) eu-central-1
欧洲地区(爱尔兰) eu-west-1
欧洲地区(伦敦) eu-west-2
欧洲(米兰) eu-south-1
欧洲地区(巴黎) eu-west-3
欧洲地区(斯德哥尔摩) eu-north-1
中东(巴林) me-south-1
中东(阿联酋) me-central-1
South America(São Paulo) sa-east-1
中国(北京) cn-north-1
中国(宁夏) cn-northwest-1
Amazon GovCloud(美国东部) us-gov-east-1
Amazon GovCloud(美国西部) us-gov-west-1