Amazon Managed Streaming for Apache Kafka 的操作、资源和条件键 - 服务授权参考
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

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

Amazon Managed Streaming for Apache Kafka 的操作、资源和条件键

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

参考:

Amazon Managed Streaming for Apache Kafka 定义的操作

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

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

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

注意

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

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

操作 描述 访问级别 资源类型(* 为必需) 条件键 相关操作
BatchAssociateScramSecret 授予将一个或多个 Scram 密钥与 Amazon MSK 集群关联的权限 Write

cluster*

kms:CreateGrant

kms:RetireGrant

BatchDisassociateScramSecret 授予取消一个或多个 Scram 密钥与 Amazon MSK 集群的关联的权限 Write

cluster*

kms:RetireGrant

CreateCluster 授予创建 MSK 集群的权限 Write

cluster*

ec2:DescribeSecurityGroups

ec2:DescribeSubnets

ec2:DescribeVpcs

iam:AttachRolePolicy

iam:CreateServiceLinkedRole

iam:PutRolePolicy

kms:CreateGrant

kms:DescribeKey

aws:RequestTag/${TagKey}

aws:TagKeys

CreateClusterV2 授予创建 MSK 集群的权限 Write

cluster*

ec2:CreateTags

ec2:CreateVpcEndpoint

ec2:DeleteVpcEndpoints

ec2:DescribeSecurityGroups

ec2:DescribeSubnets

ec2:DescribeVpcAttribute

ec2:DescribeVpcEndpoints

ec2:DescribeVpcs

iam:AttachRolePolicy

iam:CreateServiceLinkedRole

iam:PutRolePolicy

kms:CreateGrant

kms:DescribeKey

aws:RequestTag/${TagKey}

aws:TagKeys

CreateConfiguration 授予创建 MSK 配置的权限 Write

configuration*

CreateReplicator 授予权限以创建 MSK 复制程序 Write

replicator*

ec2:DescribeSecurityGroups

ec2:DescribeSubnets

ec2:DescribeVpcs

iam:AttachRolePolicy

iam:CreateServiceLinkedRole

iam:PassRole

iam:PutRolePolicy

kafka:DescribeClusterV2

kafka:GetBootstrapBrokers

aws:RequestTag/${TagKey}

aws:TagKeys

CreateVpcConnection 授予创建 MSK VPC 连接的权限 Write

cluster*

ec2:CreateTags

ec2:CreateVpcEndpoint

ec2:DescribeSecurityGroups

ec2:DescribeSubnets

ec2:DescribeVpcAttribute

ec2:DescribeVpcEndpoints

ec2:DescribeVpcs

iam:AttachRolePolicy

iam:CreateServiceLinkedRole

iam:PutRolePolicy

vpc-connection*

aws:RequestTag/${TagKey}

aws:TagKeys

DeleteCluster 授予删除 MSK 集群的权限 Write

cluster*

ec2:DeleteVpcEndpoints

ec2:DescribeVpcAttribute

ec2:DescribeVpcEndpoints

DeleteClusterPolicy 授予权限以删除集群基于资源的策略 Write

cluster*

DeleteConfiguration 授予删除指定 MSK 配置的权限 Write

configuration*

DeleteReplicator 授予权限以删除 MSK 复制程序 Write

replicator*

DeleteVpcConnection 授予删除 MSK VPC 连接的权限 Write

vpc-connection*

ec2:DeleteVpcEndpoints

ec2:DescribeVpcEndpoints

DescribeCluster 授予描述 MSK 集群的权限 Read

cluster*

DescribeClusterOperation 授予描述给定 ARN 指定的集群操作的权限 Read
DescribeClusterOperationV2 授予描述给定 ARN 指定的集群操作的权限 Read
DescribeClusterV2 授予描述 MSK 集群的权限 Read

cluster*

DescribeConfiguration 授予描述 MSK 配置的权限 Read

configuration*

DescribeConfigurationRevision 授予描述 MSK 配置修订的权限 Read

configuration*

DescribeReplicator 授予权限以描述 MSK 复制程序 Read

replicator*

DescribeVpcConnection 授予描述 MSK VPC 连接的权限 Read

vpc-connection*

GetBootstrapBrokers 授予获取 MSK 集群中的代理的连接详细信息的权限 Read
GetClusterPolicy 授予描述集群基于资源的策略的权限 Read

cluster*

GetCompatibleKafkaVersions 授予获取可将 MSK 集群更新到其中的 Apache Kafka 版本列表的权限 List
ListClientVpcConnections 授予列出为某相集群创建的所有 MSK VPC 连接的权限 List

cluster*

ListClusterOperations 授予权限以返回已在指定 MSK 集群上执行的所有操作列表 List

cluster*

ListClusterOperationsV2 授予权限以返回已在指定 MSK 集群上执行的所有操作列表 List

cluster*

ListClusters 授予列出此账户中所有 MSK 集群的权限 List
ListClustersV2 授予列出此账户中所有 MSK 集群的权限 List
ListConfigurationRevisions 授予列出此账户中 MSK 配置的所有修订的权限 List

configuration*

ListConfigurations 授予列出此账户中所有 MSK 配置的权限 List
ListKafkaVersions 授予列出 Amazon MSK 支持的所有 Apache Kafka 版本的权限 List
ListNodes 授予列出 MSK 集群中代理的权限 List

cluster*

ListReplicators 授予权限以列出此账户中所有 MSK 复制程序 List
ListScramSecrets 授予列出与 Amazon MSK 集群关联的 Scram 密钥的权限 List

cluster*

ListTagsForResource 授予列出 MSK 资源的标签的权限 Read

cluster*

ListVpcConnections 授予列出此账户使用的所有 MSK VPC 连接的权限 List
PutClusterPolicy 授予权限以创建或更新集群的基于资源的策略 Write

cluster*

RebootBroker 授予重启代理的权限 Write

cluster*

RejectClientVpcConnection 授予拒绝 MSK VPC 连接的权限 Write

cluster*

vpc-connection*

TagResource 授予标记 MSK 资源的权限 Tagging

cluster

vpc-connection

aws:RequestTag/${TagKey}

aws:TagKeys

UntagResource 授予从 MSK 资源中删除标签的权限 Tagging

cluster

vpc-connection

aws:TagKeys

UpdateBrokerCount 授予权限以更新 MSK 集群代理数量 Write

cluster*

UpdateBrokerStorage 授予权限以更新 MSK 集群代理的存储大小 Write

cluster*

UpdateBrokerType 授予权限以更新 Amazon MSK 集群的代理类型 Write

cluster*

UpdateClusterConfiguration 授予更新 MSK 集群配置的权限 Write

cluster*

configuration*

UpdateClusterKafkaVersion 授予将 MSK 集群更新到指定 Apache Kafka 版本的权限 Write

cluster*

UpdateConfiguration 授予创建新修订版 MSK 配置的权限 Write

configuration*

UpdateConnectivity 授予更新 MSK 集群连接性设置的权限 Write

cluster*

ec2:DescribeRouteTables

ec2:DescribeSubnets

kafka:publicAccessEnabled

UpdateMonitoring 授予更新 MSK 集群监控设置的权限 Write

cluster*

UpdateReplicationInfo 授予权限以更新 MSK 复制程序的复制信息 Write

replicator*

UpdateSecurity 授予更新 MSK 集群安全设置的权限 Write

cluster*

kms:RetireGrant

UpdateStorage 授予更新与 MSK 代理关联的 EBS 存储(大小或预置吞吐量)或将集群存储模式设置为 TIERED 的权限 Write

cluster*

Amazon Managed Streaming for Apache Kafka 定义的资源类型

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

资源类型 ARN 条件键
cluster arn:${Partition}:kafka:${Region}:${Account}:cluster/${ClusterName}/${Uuid}

aws:ResourceTag/${TagKey}

configuration arn:${Partition}:kafka:${Region}:${Account}:configuration/${ConfigurationName}/${Uuid}
vpc-connection arn:${Partition}:kafka:${Region}:${VpcOwnerAccount}:vpc-connection/${ClusterOwnerAccount}/${ClusterName}/${Uuid}

aws:ResourceTag/${TagKey}

replicator arn:${Partition}:kafka:${Region}:${Account}:replicator/${ReplicatorName}/${Uuid}

aws:ResourceTag/${TagKey}

topic arn:${Partition}:kafka:${Region}:${Account}:topic/${ClusterName}/${ClusterUuid}/${TopicName}
group arn:${Partition}:kafka:${Region}:${Account}:group/${ClusterName}/${ClusterUuid}/${GroupName}
transactional-id arn:${Partition}:kafka:${Region}:${Account}:transactional-id/${ClusterName}/${ClusterUuid}/${TransactionalId}

Amazon Managed Streaming for Apache Kafka 的条件键

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

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

条件键 描述 类型
aws:RequestTag/${TagKey} 根据在请求中是否具有标签键值对来筛选访问权限 字符串
aws:ResourceTag/${TagKey} 按附加到资源的标签键值对筛选操作 字符串
aws:TagKeys 根据在请求中是否具有标签键来筛选访问 字符串数组
kafka:publicAccessEnabled 根据在请求中是否启用了公有访问来筛选访问权限 Bool