View a markdown version of this page

Amazon EMR 如何与 IAM 配合使用 - Amazon EMR

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

Amazon EMR 如何与 IAM 配合使用

在使用 IAM 管理对 Amazon EMR 的访问权限之前,您应该了解哪些 IAM 功能可用于 Amazon EMR。

将 IAM 功能与 Amazon EMR 一起使用
IAM 功能 Amazon EMR 支持

Identity-based 政策

Resource-based 政策

策略操作

策略资源

策略条件键

ACL

ABAC(策略中的标签)

临时凭证

主体权限

服务角色

Service-linked 角色

要全面了解 Amazon EMR 和其他 AWS 服务如何与大多数 IAM 功能配合使用,请参阅 IAM 用户指南中与 IAM 配合使用的AWS 服务

Identity-based 亚马逊 EMR 的政策

支持基于身份的策略:

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

通过使用 IAM 基于身份的策略,您可以指定允许或拒绝的操作和资源以及允许或拒绝操作的条件。要了解可在 JSON 策略中使用的所有元素,请参阅《IAM 用户指南》中的 IAM JSON 策略元素引用

Identity-based 亚马逊 EMR 的政策示例

要查看 Amazon EMR 基于身份的策略的示例,请参阅Amazon EMR 基于身份的策略示例

Resource-based 亚马逊 EMR 中的政策

支持基于资源的策略:

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

要启用跨账户访问,您可以将整个账户或其他账户中的 IAM 实体指定为基于资源的策略中的主体。有关更多信息,请参阅《IAM 用户指南》中的 IAM 中的跨账户资源访问

Amazon EMR 的策略操作

支持策略操作:

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

JSON 策略的 Action 元素描述可用于在策略中允许或拒绝访问的操作。在策略中包含操作以授予执行关联操作的权限。

要查看 Amazon EMR 操作的列表,请参阅《服务授权参考》中的 Amazon EMR 的操作、资源和条件键

Amazon EMR 中的策略操作在操作前面使用以下前缀:

EMR

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

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

要查看 Amazon EMR 基于身份的策略的示例,请参阅Amazon EMR 基于身份的策略示例

Amazon EMR 的策略资源

支持策略资源:

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

Resource JSON 策略元素指定要向其应用操作的一个或多个对象。作为最佳实践,请使用其 Amazon 资源名称(ARN)指定资源。对于不支持资源级权限的操作,请使用通配符 (*) 指示语句应用于所有资源。

"Resource": "*"

要查看 Amazon EMR 的资源类型及其 ARN 的列表,请参阅《服务授权参考》中的由 Amazon EMR 定义的资源。要了解可以为每个资源的 ARN 指定哪些操作,请参阅 Amazon EMR 的操作、资源和条件键

要查看 Amazon EMR 基于身份的策略的示例,请参阅Amazon EMR 基于身份的策略示例

Amazon EMR 的策略条件键

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

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

Condition 元素根据定义的条件指定语句何时执行。您可以创建使用条件运算符(例如,等于或小于)的条件表达式,以使策略中的条件与请求中的值相匹配。要查看所有 AWS 全局条件键,请参阅 IAM 用户指南中的AWS 全局条件上下文密钥

要查看 Amazon EMR 条件键的列表,并了解您可以对哪些操作和资源使用条件键,请参阅《服务授权参考》中的 Amazon EMR 的操作、资源和条件键

要查看 Amazon EMR 基于身份的策略的示例,请参阅Amazon EMR 基于身份的策略示例

Amazon EMR 中的访问控制列表(ACL)

支持 ACL:

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

Attribute-based 使用亚马逊 EMR 进行访问控制 (ABAC)

支持 ABAC(策略中的标签)

Attribute-based 访问控制 (ABAC) 是一种授权策略,它根据称为标签的属性来定义权限。您可以将标签附加到 IAM 实体和 AWS 资源,然后设计 ABAC 策略以允许在委托人的标签与资源上的标签匹配时进行操作。

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

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

有关 ABAC 的更多信息,请参阅《IAM 用户指南》中的使用 ABAC 授权定义权限。要查看设置 ABAC 步骤的教程,请参阅《IAM 用户指南》中的使用基于属性的访问权限控制(ABAC)

使用 Amazon EMR 的临时凭证

支持临时凭证:

临时证书提供对 AWS 资源的短期访问权限,并且是在您使用联合身份或切换角色时自动创建的。 AWS 建议您动态生成临时证书,而不是使用长期访问密钥。有关更多信息,请参阅《IAM 用户指南》中的 IAM 中的临时安全凭证使用 IAM 的。AWS 服务

Cross-service 亚马逊 EMR 的主要权限

支持转发访问会话(FAS):

转发访问会话 (FAS) 使用调用主体的权限 AWS 服务,再加上 AWS 服务 向下游服务发出请求的请求。有关发出 FAS 请求时的策略详情,请参阅转发访问会话

Amazon EMR 的服务角色

支持服务角色

Service-linked 亚马逊 EMR 的角色

支持服务相关角色

有关创建或管理服务相关角色的详细信息,请参阅使用 IAM 的AWS 服务。在表中查找Service-linked 角色Yes中包含的服务。选择链接以查看该服务的服务相关角色文档。

将集群和 Notebook 标签与访问控制 IAM policy 结合使用

可以将基于标签的访问控制与基于身份的 IAM policy 结合使用,精细调整与 EMR Notebooks 和 EMR 集群关联的 Amazon EMR 操作的权限。您可以使用 Condition 元素中的条件键(也称作 Condition 数据块),来允许仅在 Notebook 和/或集群具有特定标签或键-值组合时执行某些操作。您也可以限制 CreateEditor 操作(创建 EMR Notebooks)和 RunJobFlow 操作(创建集群),这样在创建资源时必须提交标签请求。

在 Amazon EMR 中,可用于 Condition 元素中的条件键仅应用于 ClusterIDNotebookID 为必需请求参数的 Amazon EMR API 操作。例如,该ModifyInstanceGroups操作不支持上下文密钥,因为ClusterID它是可选参数。

您创建 EMR Notebook 时,系统会应用一个默认标签,其中 creatorUserId 的键字符串会设置为创建 Notebook 的 IAM 用户 ID 的值。这在将 Notebook 的允许操作仅限定为创建者时非常有用。

以下条件键可用于 Amazon EMR 中:

  • 使用 elasticmapreduce:ResourceTag/TagKeyString 条件上下文键可允许或拒绝用户对带有您指定的 TagKeyString 的标签的集群或 Notebook 执行操作。如果某个操作同时传递 ClusterIDNotebookID,则该条件同时适用于集群和 Notebook。这意味着这两个资源都必须具有您指定的标签键字符串或键-值组合。您可以使用 Resource 元素来限制语句,以便它能根据需要仅适用于集群或 Notebook。有关更多信息,请参阅 Amazon EMR 基于身份的策略示例

  • 使用elasticmapreduce:RequestTag/TagKeyString条件上下文密钥要求使用带有 actions/API 调用的特定标签。例如,您可以将此条件上下文键与 CreateEditor 操作一起使用,以在创建 Notebook 时对其应用 TagKeyString

示例

要查看 Amazon EMR 操作的列表,请参阅《IAM 用户指南》中的 Amazon EMR 定义的操作