亚马逊是如何 SageMaker 与之合作的 IAM - Amazon SageMaker

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

亚马逊是如何 SageMaker 与之合作的 IAM

重要

允许 Amazon SageMaker Studio 或 Amazon SageMaker Studio Classic 创建亚马逊 SageMaker资源的自定义IAM策略还必须授予向这些资源添加标签的权限。需要向资源添加标签的权限,因为 Studio 和 Studio Classic 会自动标记他们创建的任何资源。如果IAM策略允许 Studio 和 Studio Classic 创建资源但不允许标记,则在尝试创建资源时可能会出现 AccessDenied “” 错误。有关更多信息,请参阅 提供标记 SageMaker资源的权限

AWS Amazon 托管政策 SageMaker授予创建 SageMaker 资源的权限已经包括在创建这些资源时添加标签的权限。

在使用管理IAM访问权限之前 SageMaker,您应该了解哪些IAM功能可供使用 SageMaker。要全面了解如何使用 SageMaker 和其他 AWS 服务IAM,请参阅AWS 《服务授权参考》IAM中的 “之配合使用的服务”。

SageMaker 基于身份的策略

使用IAM基于身份的策略,您可以指定允许或拒绝的操作和资源,以及允许或拒绝操作的条件。 SageMaker 支持特定的操作、资源和条件键。要了解您在JSON策略中使用的所有元素,请参阅服务授权参考中的IAMJSON策略元素参考

操作

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

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

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

正在执行的策略操作在操作前 SageMaker 使用以下前缀:sagemaker:. 例如,要授予某人使用该操作运行 SageMaker 训练作业的权限,您可以将该 SageMakerCreateTrainingJobAPIsagemaker:CreateTrainingJob操作包含在他们的策略中。策略声明必须包含ActionNotAction元素。 SageMaker 定义了它自己的一组操作,这些操作描述了您可以使用此服务执行的任务。

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

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

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

"Action": "sagemaker:Describe*"

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

资源

SageMaker 不支持在策略ARNs中指定资源。

条件键

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

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

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

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

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

SageMaker 定义自己的条件键集,还支持使用一些全局条件键。要查看所有 AWS 全局条件密钥,请参阅《服务授权参考》中的AWS 全局条件上下文密钥

SageMaker 支持许多特定于服务的条件密钥,您可以使用这些条件密钥对以下操作进行精细的访问控制:

要查看 SageMaker 条件密钥列表,请参阅《服务授权参考》 SageMaker 中的 Amazon 条件密钥。要了解您可以使用条件键的操作和资源,请参阅 Amazon 定义的操作 SageMaker

有关使用 SageMaker 条件键的示例,请参阅以下内容:使用条件键控制 SageMaker 资源的创建

示例

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

SageMaker 基于资源的政策

SageMaker 不支持基于资源的策略。

基于 SageMaker 标签的授权

您可以为 SageMaker 资源附加标签或在请求中传递标签 SageMaker。要基于标签控制访问,您需要使用 sagemaker:ResourceTag/key-nameaws:RequestTag/key-nameaws:TagKeys 条件键在策略的条件元素中提供标签信息。有关为 SageMaker 资源添加标签的更多信息,请参阅使用标签控制对 SageMaker 资源的访问权限

要查看基于身份的策略(用于根据资源上的标签来限制对该资源的访问)的示例,请参阅使用标签控制对 SageMaker 资源的访问权限

SageMaker IAM角色

IAM角色是您的 AWS 账户中具有特定权限的实体。

将临时证书用于 SageMaker

您可以使用临时证书通过联合身份登录、代入IAM角色或担任跨账户角色。您可以通过调用AssumeRole或之类的 AWS STS API操作来获取临时安全证书GetFederationToken

SageMaker 支持使用临时证书。

服务相关角色

SageMaker 部分支持服务相关角色。 SageMaker Studio Classic 目前提供服务相关角色。

服务角色

此功能允许服务代表您担任服务角色。此角色允许服务访问其他服务中的资源以代表您完成操作。服务角色显示在您的IAM账户中,并归该账户所有。这意味着IAM管理员可以更改此角色的权限。但是,这样做可能会中断服务的功能。

SageMaker 支持服务角色。

在中选择IAM角色 SageMaker

在中创建 notebook 实例、处理作业、训练作业、托管端点或批量转换作业资源时 SageMaker,必须选择 SageMaker 允许您访问 SageMaker 的角色。如果您之前创建过服务角色或服务相关角色,则会 SageMaker 为您提供可供选择的角色列表。选择一个允许访问所需 AWS 操作和资源的角色非常重要。有关更多信息,请参阅 如何使用 SageMaker 执行角色