Amazon MemoryDB 的操作、资源和条件密钥 - 服务授权参考

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

Amazon MemoryDB 的操作、资源和条件密钥

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

参考:

Amazon MemoryDB 定义的操作

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

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

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

注意

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

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

注意

在 IAM 中为 Redis 策略创建 MemoryDB 时,必须为资源块使用 "*" 通配符。有关在 IAM policy 中使用以下 MemoryDB for Redis API 操作的信息,请参阅 MemoryDB 操作和 IAM

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
BatchUpdateCluster 授予应用服务更新的权限 写入

cluster*

ec2:CreateNetworkInterface

ec2:DeleteNetworkInterface

ec2:DescribeNetworkInterfaces

ec2:DescribeSubnets

ec2:DescribeVpcs

s3:GetObject

aws:ResourceTag/${TagKey}

Connect 允许 IAM 用户或角色作为指定的 MemoryDB 用户连接到集群中的节点 写入

cluster*

user*

aws:ResourceTag/${TagKey}

CopySnapshot 授予权限以复制现有快照 写入

snapshot*

memorydb:TagResource

s3:DeleteObject

s3:GetBucketAcl

s3:PutObject

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

CreateAcl 授予权限以创建新的访问控制列表 写入

user*

memorydb:TagResource

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

CreateCluster 授予权限以创建集群 写入

acl*

ec2:CreateNetworkInterface

ec2:DeleteNetworkInterface

ec2:DescribeNetworkInterfaces

ec2:DescribeSubnets

ec2:DescribeVpcs

memorydb:TagResource

s3:GetObject

parametergroup*

subnetgroup*

snapshot

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

memorydb:TLSEnabled

CreateParameterGroup 授予权限以创建新的参数组 写入

aws:RequestTag/${TagKey}

aws:TagKeys

memorydb:TagResource

CreateSnapshot 授予在当前时间点创建群集备份的权限 写入

cluster*

memorydb:TagResource

s3:DeleteObject

s3:GetBucketAcl

s3:PutObject

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

CreateSubnetGroup 授予权限以创建新的子网组 写入

aws:RequestTag/${TagKey}

aws:TagKeys

memorydb:TagResource

CreateUser 授予权限以创建新用户 写入

aws:RequestTag/${TagKey}

aws:TagKeys

memorydb:UserAuthenticationMode

memorydb:TagResource

DeleteAcl 授予权限以删除访问控制列表 写入

acl*

aws:ResourceTag/${TagKey}

DeleteCluster 授予权限以删除以前预配置的集群 写入

cluster*

ec2:CreateNetworkInterface

ec2:DeleteNetworkInterface

ec2:DescribeNetworkInterfaces

ec2:DescribeSubnets

ec2:DescribeVpcs

snapshot

aws:ResourceTag/${TagKey}

DeleteParameterGroup 授予权限以删除参数组 写入

parametergroup*

aws:ResourceTag/${TagKey}

DeleteSnapshot 授予权限以删除快照 写入

snapshot*

aws:ResourceTag/${TagKey}

DeleteSubnetGroup 授予删除子网组的权限 写入

subnetgroup*

ec2:CreateNetworkInterface

ec2:DeleteNetworkInterface

ec2:DescribeNetworkInterfaces

ec2:DescribeSubnets

ec2:DescribeVpcs

aws:ResourceTag/${TagKey}

DeleteUser 授予权限,以删除用户 写入

user*

aws:ResourceTag/${TagKey}

DescribeAcls 授予权限以检索有关 IP 访问控制列表的信息 读取

acl*

aws:ResourceTag/${TagKey}

DescribeClusters 如果未指定集群标识符,则授予检索有关所有已设置集群的信息的权限;如果提供了集群标识符,则授予检索有关特定集群的信息的权限 读取

cluster*

aws:ResourceTag/${TagKey}

DescribeEngineVersions 授予权限以列出可用的引擎及其版本 读取
DescribeEvents 授予权限以检索与集群、子网组和参数组相关的事件 读取
DescribeParameterGroups 授予权限以检索有关参数组的信息 读取

parametergroup*

aws:ResourceTag/${TagKey}

DescribeParameters 授予权限以检索特定参数组的详细参数列表 读取

parametergroup*

aws:ResourceTag/${TagKey}

DescribeReservedNodes 授予检索预留节点的权限 读取

reservednode*

aws:ResourceTag/${TagKey}

DescribeReservedNodesOfferings 授予检索预留节点产品的权限 读取
DescribeServiceUpdates 授予权限以检索服务更新详细信息 读取
DescribeSnapshots 授予权限以检索有关集群快照的信息 读取

snapshot*

aws:ResourceTag/${TagKey}

DescribeSubnetGroups 授予权限以检索子网组列表 读取

subnetgroup*

aws:ResourceTag/${TagKey}

DescribeUsers 授予权限以检索有关用户的信息 读取

user*

aws:ResourceTag/${TagKey}

FailoverShard 授予权限以测试集群中的指定分片上的自动故障转移 写入

cluster*

ec2:CreateNetworkInterface

ec2:DeleteNetworkInterface

ec2:DescribeNetworkInterfaces

ec2:DescribeSubnets

ec2:DescribeVpcs

aws:ResourceTag/${TagKey}

ListAllowedNodeTypeUpdates 授予列出可用节点类型更新的权限 读取

cluster*

aws:ResourceTag/${TagKey}

ListTags 授予列出成本分配标签的权限 读取

acl

cluster

parametergroup

snapshot

subnetgroup

user

aws:ResourceTag/${TagKey}

PurchaseReservedNodesOffering 授予购买新预留节点的权限 写入

reservednode*

memorydb:TagResource

aws:ResourceTag/${TagKey}

aws:RequestTag/${TagKey}

aws:TagKeys

ResetParameterGroup 授予权限以将参数组的参数修改为引擎或者系统默认值 写入

parametergroup*

aws:ResourceTag/${TagKey}

TagResource 授予将最多 10 个成本分配标签添加到命名资源的权限 标记

acl

cluster

parametergroup

reservednode

snapshot

subnetgroup

user

aws:TagKeys

aws:RequestTag/${TagKey}

aws:ResourceTag/${TagKey}

UntagResource 授予从资源中移除 TagKeys 列表标识的标签的权限 标记

acl

cluster

parametergroup

snapshot

subnetgroup

user

aws:TagKeys

aws:ResourceTag/${TagKey}

UpdateAcl 授予更新访问控制规则的权限 写入

acl*

user*

aws:ResourceTag/${TagKey}

UpdateCluster 授予更新集群设置的权限 写入

cluster*

ec2:CreateNetworkInterface

ec2:DeleteNetworkInterface

ec2:DescribeNetworkInterfaces

ec2:DescribeSubnets

ec2:DescribeVpcs

acl

parametergroup

aws:ResourceTag/${TagKey}

UpdateParameterGroup 授予权限以更新参数组的参数 写入

parametergroup*

aws:ResourceTag/${TagKey}

UpdateSubnetGroup 授予权限以更新子网组 写入

subnetgroup*

aws:ResourceTag/${TagKey}

UpdateUser 授予权限以更新用户 写入

user*

aws:ResourceTag/${TagKey}

memorydb:UserAuthenticationMode

Amazon MemoryDB 定义的资源类型

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

资源类型 ARN 条件键
parametergroup arn:${Partition}:memorydb:${Region}:${Account}:parametergroup/${ParameterGroupName}

aws:ResourceTag/${TagKey}

subnetgroup arn:${Partition}:memorydb:${Region}:${Account}:subnetgroup/${SubnetGroupName}

aws:ResourceTag/${TagKey}

cluster arn:${Partition}:memorydb:${Region}:${Account}:cluster/${ClusterName}

aws:ResourceTag/${TagKey}

snapshot arn:${Partition}:memorydb:${Region}:${Account}:snapshot/${SnapshotName}

aws:ResourceTag/${TagKey}

user arn:${Partition}:memorydb:${Region}:${Account}:user/${UserName}

aws:ResourceTag/${TagKey}

acl arn:${Partition}:memorydb:${Region}:${Account}:acl/${AclName}

aws:ResourceTag/${TagKey}

reservednode arn:${Partition}:memorydb:${Region}:${Account}:reservednode/${ReservationID}

aws:ResourceTag/${TagKey}

Amazon MemoryDB 的条件密钥

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

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

条件键 描述 类型
aws:RequestTag/${TagKey} 根据在请求中传递的标签筛选操作 字符串
aws:ResourceTag/${TagKey} 根据与资源关联的标签筛选操作 字符串
aws:TagKeys 根据在请求中传递的标签键筛选操作 ArrayOfString
memorydb:TLSEnabled 按请求中存在的 tlseNabled 参数过滤访问权限,如果参数不存在,则默认为真值 布尔型
memorydb:UserAuthenticationMode 按请求中的 UserAuthenticationMode .Type 参数筛选访问权限 String