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

AWS App Mesh 的操作、资源和条件键

AWS App Mesh(服务前缀:appmesh)提供以下服务特定的资源、操作和条件上下文键以在 IAM 权限策略中使用。

参考:

AWS App Mesh 定义的操作

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

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

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

注意

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

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
CreateGatewayRoute 授予创建与虚拟网关关联的网关路由的权限 Write

gatewayRoute*

aws:TagKeys

aws:RequestTag/${TagKey}

virtualService

CreateMesh 授予创建服务网格的权限 Write

mesh*

aws:TagKeys

aws:RequestTag/${TagKey}

CreateRoute 授予创建与虚拟路由器关联的路由的权限 Write

route*

aws:TagKeys

aws:RequestTag/${TagKey}

virtualNode

CreateVirtualGateway 授予在服务网格中创建虚拟网关的权限 Write

virtualGateway*

aws:TagKeys

aws:RequestTag/${TagKey}

CreateVirtualNode 授予在服务网格中创建虚拟节点的权限 Write

virtualNode*

aws:TagKeys

aws:RequestTag/${TagKey}

virtualService

CreateVirtualRouter 授予在服务网格中创建虚拟路由器的权限 Write

virtualRouter*

aws:TagKeys

aws:RequestTag/${TagKey}

CreateVirtualService 授予在服务网格中创建虚拟服务的权限 Write

virtualService*

aws:TagKeys

aws:RequestTag/${TagKey}

virtualNode

virtualRouter

DeleteGatewayRoute 授予删除现有网关路由的权限 Write

gatewayRoute*

DeleteMesh 授予删除现有服务网格的权限 写入

mesh*

DeleteMeshPolicy [仅权限] 授予权限以删除网格的 RAM 访问控制策略 写入

mesh*

DeleteRoute 授予删除现有路由的权限 Write

route*

DeleteVirtualGateway 授予删除现有虚拟网关的权限 Write

virtualGateway*

DeleteVirtualNode 授予删除现有虚拟节点的权限 Write

virtualNode*

DeleteVirtualRouter 授予删除现有虚拟路由器的权限 Write

virtualRouter*

DeleteVirtualService 授予删除现有虚拟服务的权限 Write

virtualService*

DescribeGatewayRoute 授予描述现有网关路由的权限 Read

gatewayRoute*

DescribeMesh 授予描述现有服务网格的权限 Read

mesh*

DescribeRoute 授予描述现有路由的权限 Read

route*

DescribeVirtualGateway 授予描述现有虚拟网关的权限 Read

virtualGateway*

DescribeVirtualNode 授予描述现有虚拟节点的权限 Read

virtualNode*

DescribeVirtualRouter 授予描述现有虚拟路由器的权限 Read

virtualRouter*

DescribeVirtualService 授予描述现有虚拟服务的权限 读取

virtualService*

GetMeshPolicy [仅权限] 授予权限以读取网格的 RAM 访问控制策略 读取

mesh*

ListGatewayRoutes 授予列出服务网格中现有网关路由的权限 List

virtualGateway*

ListMeshes 授予列出现有服务网格的权限 List
ListRoutes 授予列出服务网格中现有路由的权限 List

virtualRouter*

ListTagsForResource 授予列出 App Mesh 资源标签的权限 List

gatewayRoute

mesh

route

virtualGateway

virtualNode

virtualRouter

virtualService

ListVirtualGateways 授予列出服务网格中现有虚拟网关的权限 List

mesh*

ListVirtualNodes 授予列出现有虚拟节点的权限 List

mesh*

ListVirtualRouters 授予列出服务网格中现有虚拟路由器的权限 List

mesh*

ListVirtualServices 授予列出服务网格中现有虚拟服务的权限 列出

mesh*

PutMeshPolicy [仅权限] 授予权限以定义网格的 RAM 访问控制策略 写入

mesh*

StreamAggregatedResources 授予接收 App Mesh 终端节点 (VirtualNode/VirtualGateway) 的流资源的权限 Read

virtualGateway

virtualNode

TagResource 授予权限以使用指定的 resourceArn 为资源贴标签 标记

gatewayRoute

mesh

route

virtualGateway

virtualNode

virtualRouter

virtualService

aws:TagKeys

aws:RequestTag/${TagKey}

UntagResource 授予权限以从资源中删除标签 标记

gatewayRoute

mesh

route

virtualGateway

virtualNode

virtualRouter

virtualService

aws:TagKeys

UpdateGatewayRoute 授予权限以更新指定服务网格和虚拟网关的现有网关路由 Write

gatewayRoute*

virtualService

UpdateMesh 授予更新现有服务网格的权限 Write

mesh*

UpdateRoute 授予更新指定服务网格和虚拟路由器的现有路由的权限 Write

route*

virtualNode

UpdateVirtualGateway 授予更新指定服务网格中现有虚拟网关的权限 Write

virtualGateway*

UpdateVirtualNode 授予更新指定服务网格中现有虚拟节点的权限 Write

virtualNode*

UpdateVirtualRouter 授予更新指定服务网格中现有虚拟路由器的权限 Write

virtualRouter*

UpdateVirtualService 授予更新指定服务网格中现有虚拟服务的权限 Write

virtualService*

virtualNode

virtualRouter

AWS App Mesh 定义的资源类型

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

资源类型 ARN 条件键
mesh arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}

aws:ResourceTag/${TagKey}

virtualService arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}/virtualService/${VirtualServiceName}

aws:ResourceTag/${TagKey}

virtualNode arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}/virtualNode/${VirtualNodeName}

aws:ResourceTag/${TagKey}

virtualRouter arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}/virtualRouter/${VirtualRouterName}

aws:ResourceTag/${TagKey}

route arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}/virtualRouter/${VirtualRouterName}/route/${RouteName}

aws:ResourceTag/${TagKey}

virtualGateway arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}/virtualGateway/${VirtualGatewayName}

aws:ResourceTag/${TagKey}

gatewayRoute arn:${Partition}:appmesh:${Region}:${Account}:mesh/${MeshName}/virtualGateway/${VirtualGatewayName}/gatewayRoute/${GatewayRouteName}

aws:ResourceTag/${TagKey}

AWS App Mesh 的条件键

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

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

条件键 描述 类型
aws:RequestTag/${TagKey} 根据在请求中是否具有标签键值对来筛选操作 String
aws:ResourceTag/${TagKey} 根据附加到资源的标签键值对来筛选操作 String
aws:TagKeys 根据在请求中是否具有标签键来筛选操作 字符串数组