AWS Cloud Map 的操作、资源和条件键 - 服务授权参考

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

AWS Cloud Map 的操作、资源和条件键

AWS Cloud Map(服务前缀:servicediscovery)提供以下特定于服务的资源、操作和条件上下文密钥,供在 IAM 权限策略中使用。

参考:

AWS Cloud Map 定义的操作

您可以在 IAM 策略语句的 Action 元素中指定以下操作。可以使用策略授予在 AWS中执行操作的权限。您在策略中使用一项操作时,通常使用相同的名称允许或拒绝对 API 操作或 CLI 命令的访问。但在某些情况下,单一动作可控制对多项操作的访问。还有某些操作需要多种不同的动作。

操作表的资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource 元素中指定策略应用的所有资源(“*”)。通过在 IAM policy 中使用条件来筛选访问权限,以控制是否可以在资源或请求中使用特定标签键。如果操作具有一个或多个必需资源,则调用方必须具有使用这些资源来使用该操作的权限。必需资源在表中以星号 (*) 表示。如果您在 IAM policy 中使用 Resource 元素限制资源访问权限,则必须为每种必需的资源类型添加 ARN 或模式。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种可选资源类型。

操作表的条件键列包括可以在策略语句的 Condition 元素中指定的键。有关与服务资源关联的条件键的更多信息,请参阅资源类型表的条件键列。

注意

资源条件键在资源类型表中列出。您可以在操作表的资源类型(* 为必需)列中找到应用于某项操作的资源类型的链接。资源类型表中的资源类型包括条件密钥列,这是应用于操作表中操作的资源条件键。

有关下表中各列的详细信息,请参阅操作表

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
CreateHttpNamespace 授予创建 HTTP 命名空间的权限 Write

aws:TagKeys

aws:RequestTag/${TagKey}

CreatePrivateDnsNamespace 授予根据 DNS 创建私有命名空间(仅在指定的 Amazon VPC 内才可见)的权限 Write

aws:TagKeys

aws:RequestTag/${TagKey}

CreatePublicDnsNamespace 授予根据 DNS 创建公有命名空间(在 Internet 上可见)的权限 Write

aws:TagKeys

aws:RequestTag/${TagKey}

CreateService 授予创建服务的权限 Write

namespace*

service*

servicediscovery:NamespaceArn

aws:TagKeys

aws:RequestTag/${TagKey}

DeleteNamespace 授予删除指定命名空间的权限 Write

namespace*

DeleteService 授予删除指定服务的权限 Write

service*

DeregisterInstance 授予删除 Amazon Route 53 为指定实例创建的记录和运行状况检查的权限(如果有) Write

service*

servicediscovery:ServiceArn

DiscoverInstances 授予为指定命名空间和服务发现注册实例的权限 读取

servicediscovery:NamespaceName

servicediscovery:ServiceName

DiscoverInstancesRevision 授予为指定的命名空间和服务发现实例修订的权限 读取

servicediscovery:NamespaceName

servicediscovery:ServiceName

GetInstance 授予获取有关指定实例的信息的权限 Read

servicediscovery:ServiceArn

GetInstancesHealthStatus 授予获取一个或多个实例的当前运行状况(正常、不正常或未知)的权限 Read

servicediscovery:ServiceArn

GetNamespace 授予获取有关命名空间信息的权限 Read

namespace*

GetOperation 授予获取有关指定操作信息的权限 Read
GetService 授予获取指定服务设置的权限 Read

service*

ListInstances 授予权限,以获取在指定服务中注册的实例的相关摘要信息 读取

servicediscovery:ServiceArn

ListNamespaces 授予获取有关命名空间信息的权限 读取
ListOperations 授予列出与指定条件匹配的操作的权限 List
ListServices 授予获取与指定筛选条件匹配的所有服务的设置的权限 读取
ListTagsForResource 授予为指定资源列出标签的权限 读取
RegisterInstance 授予根据指定服务中的设置注册实例的权限 Write

service*

servicediscovery:ServiceArn

TagResource 授予将一个或多个标签添加到指定资源的权限 Tagging

aws:TagKeys

aws:RequestTag/${TagKey}

UntagResource 授予从指定资源中删除一个或多个标签的权限 标记

aws:TagKeys

UpdateHttpNamespace 授予权限以更新 HTTP 命名空间的设置 写入

namespace*

UpdateInstanceCustomHealthStatus 授予权限以更新具有自定义运行状况检查的实例的当前健康状态 写入

servicediscovery:ServiceArn

UpdatePrivateDnsNamespace 授予权限以更新私有 DNS 命名空间的设置 写入

namespace*

UpdatePublicDnsNamespace 授予权限以更新公有 DNS 命名空间的设置 写入

namespace*

UpdateService 授予更新指定服务中设置的权限 Write

service*

AWS Cloud Map 定义的资源类型

以下资源类型是由该服务定义的,可以在 IAM 权限策略语句的 Resource 元素中使用这些资源类型。操作表中的每个操作指定了可以使用该操作指定的资源类型。您也可以在策略中包含条件键,从而定义资源类型。这些键显示在资源类型表的最后一列。有关下表中各列的详细信息,请参阅资源类型表

资源类型 ARN 条件键
namespace arn:${Partition}:servicediscovery:${Region}:${Account}:namespace/${NamespaceId}

aws:ResourceTag/${TagKey}

service arn:${Partition}:servicediscovery:${Region}:${Account}:service/${ServiceId}

aws:ResourceTag/${TagKey}

AWS Cloud Map 的条件键

AWS Cloud Map 定义了以下可在 IAM 策略Condition元素中使用的条件键。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表

要查看适用于所有服务的全局条件键,请参阅可用的全局条件键

条件键 描述 类型
aws:RequestTag/${TagKey} 根据在请求中传递的标签筛选操作 字符串
aws:ResourceTag/${TagKey} 根据与资源关联的标签筛选操作 字符串
aws:TagKeys 根据在请求中传递的标签键筛选操作 ArrayOfString
servicediscovery:NamespaceArn 通过为相关命名空间指定 Amazon Resource Name (ARN) 来筛选访问权限 ARN
servicediscovery:NamespaceName 通过指定相关命名空间的名称来筛选访问权限 字符串
servicediscovery:ServiceArn 通过为相关服务指定 Amazon Resource Name (ARN) 来筛选访问权限 ARN
servicediscovery:ServiceName 通过指定相关服务的名称来筛选访问权限 String