Amazon 弹性容器注册表的工作原理 IAM - 亚马逊 ECR

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

Amazon 弹性容器注册表的工作原理 IAM

在使用管理IAM对亚马逊的访问权限之前ECR,您应该了解亚马逊可以使用哪些IAM功能ECR。要全面了解亚马逊ECR和其他 AWS 服务的使用方式IAM,请参阅《IAM用户指南》IAM中的 “与之配合使用的AWS 服务”。

Amazon ECR 基于身份的政策

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

操作

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

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

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

Amazon中的策略操作在操作前ECR使用以下前缀:ecr:. 例如,要授予某人使用亚马逊操作创建亚马逊ECR存储库的权限,您需要将该ECRCreateRepositoryAPIecr:CreateRepository操作包含在他们的策略中。策略语句必须包含 ActionNotAction 元素。Amazon ECR 定义了自己的一组操作,这些操作描述了您可以使用此服务执行的任务。

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

"Action": [ "ecr:action1", "ecr:action2"

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

"Action": "ecr:Describe*"

要查看亚马逊ECR操作列表,请参阅IAM用户指南中的亚马逊弹性容器注册表的操作、资源和条件密钥

资源

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

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

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

"Resource": "*"

Amazon ECR 存储库资源具有以下内容ARN:

arn:${Partition}:ecr:${Region}:${Account}:repository/${Repository-name}

有关格式的更多信息ARNs,请参阅 Amazon 资源名称 (ARNs) 和 AWS 服务命名空间

例如,要在语句中指定us-east-1区域中的my-repo存储库,请使用以下命令ARN:

"Resource": "arn:aws:ecr:us-east-1:123456789012:repository/my-repo"

要指定属于特定账户的所有存储库,请使用通配符 (*):

"Resource": "arn:aws:ecr:us-east-1:123456789012:repository/*"

要在单个语句中指定多个资源,请ARNs用逗号分隔。

"Resource": [ "resource1", "resource2"

要查看亚马逊ECR资源类型及其列表ARNs,请参阅IAM用户指南中的亚马逊弹性容器注册表定义的资源。要了解您可以为每种资源指定哪些操作,请参阅 Amazon Elastic Container Registry 定义的操作。ARN

条件键

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

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

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

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

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

Amazon ECR 定义了自己的条件键集,还支持使用一些全局条件键。要查看所有 AWS 全局条件键,请参阅IAM用户指南中的AWS 全局条件上下文密钥

大多数 Amazon ECR 操作都支持aws:ResourceTagecr:ResourceTag条件键。有关更多信息,请参阅 使用基于标签的访问控制

要查看亚马逊ECR条件密钥列表,请参阅IAM用户指南中的亚马逊弹性容器注册表定义的条件密钥。要了解您可以对哪些操作和资源使用条件键,请参阅 Amazon Elastic Container Registry 定义的操作

示例

要查看 Amazon ECR 基于身份的政策示例,请参阅。Amazon Elastic Container Registry 基于身份的策略示例

Amazon ECR 基于资源的政策

基于资源的JSON策略是政策文件,规定了指定委托人可以在什么条件下对 Amazon ECR 资源执行哪些操作。亚马逊ECR支持针对亚马逊ECR存储库的基于资源的权限策略。基于资源的策略允许您基于资源向其他账户授予使用权限。您也可以使用基于资源的策略来允许 AWS 服务访问您的 Amazon ECR 存储库。

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

Amazon ECR 服务仅支持一种基于资源的策略,即存储库策略,该策略附加到存储库。这个策略定义哪些委托人实体(账户、用户、角色和联合身份用户)可以在存储库上执行操作。要了解如何将基于资源的策略附加到存储库,请参阅Amazon ECR 中的私有存储库政策

注意

在 Amazon ECR 存储库策略中,策略元素Sid支持IAM策略中不支持的其他字符和间距。

示例

要查看 Amazon ECR 基于资源的政策的示例,请参阅 Amazon ECR 中的私有存储库策略示例

基于亚马逊ECR标签的授权

您可以为亚马逊ECR资源附加标签,也可以在请求中将标签传递给亚马逊ECR。要基于标签控制访问,您需要使用 ecr:ResourceTag/key-nameaws:RequestTag/key-nameaws:TagKeys 条件键在策略的条件元素中提供标签信息。有关为 Amazon ECR 资源添加标签的更多信息,请参阅在 Amazon 中为私有仓库添加标签 ECR

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

亚马逊ECRIAM角色

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

在 Amazon 上使用临时证书 ECR

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

亚马逊ECR支持使用临时证书。

服务相关角色

服务相关角色允许 AWS 服务访问其他服务中的资源以代表您完成操作。服务相关角色显示在您的IAM账户中,并归服务所有。IAM管理员可以查看但不能编辑服务相关角色的权限。

Amazon ECR 支持服务相关角色。有关更多信息,请参阅 使用适用于 Amazon 的服务相关角色 ECR