Amazon Keyspaces 中的读/写容量模式 - Amazon Keyspaces(针对 Apache Cassandra)
AWS 文档中描述的 AWS 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 AWS 服务入门

Amazon Keyspaces 中的读/写容量模式

Amazon Keyspaces (for Apache Cassandra) 具有两个读/写容量模式来处理表的读写:

  • 按需(默认)

  • 已预置

您选择的读/写容量模式控制对读写吞吐量收费的方式以及管理表吞吐容量的方式。

按需容量模式

Amazon Keyspaces (for Apache Cassandra) 按需 容量模式是一个灵活的计费选项,可以每秒处理数千个请求而不需要进行容量规划。此选项针对读写请求提供按请求支付定价,以便您只需为使用的资源付费。

选择按需模式时,Amazon Keyspaces 可以将表的吞吐容量立即扩展到以前达到的任何流量级别,然后在应用程序流量减少时调整回来。如果工作负载的流量级别达到新的峰值,则该服务会迅速调整以便为您的表增加吞吐容量。您可以为新表和现有表启用按需容量模式。

如果满足以下任意条件,则按需模式是很好的选项:

  • 您创建工作负载未知的新表。

  • 您具有不可预测的应用程序流量。

  • 您更喜欢只为您使用的容量付费。

要开始使用按需模式,您可以使用 AWS 管理控制台或使用几行 Cassandra 查询语言 (CQL) 代码创建新表或更新现有表以使用按需容量模式。有关更多信息,请参阅Tables

读取请求单位和写入请求单位

对于按需容量模式表,您无需预先指定预期应用程序的读取和写入吞吐量。Amazon Keyspaces 会按照读取请求单位 (RRU) 和写入请求单位 (WRU) 对在表上执行的读取和写入操作收费。

  • 对于大小不超过 4 KB 的行,一个 RRU 代表一个 LOCAL_QUORUM 读取请求或两个 LOCAL_ONE 读取请求。如果您需要读取大于 4 KB 的行,则读取操作将使用额外的 RRU。所需的 RRU 总数取决于行大小,以及要使用 LOCAL_QUORUM 还是 LOCAL_ONE 读取一致性。例如,使用 LOCAL_QUORUM 读取一致性读取一个 8 KB 行需要 2 个 RRU,如果选择 LOCAL_ONE 读取一致性,则需要 1 RRU。

  • 一个 WRU 表示对大小不超过 1 KB 的行一次写入。所有写入操作都使用 LOCAL_QUORUM 一致性,使用轻量级事务 (LWT) 不收取额外费用。如果需要写入大于 1 KB 的行,则写入操作将使用额外的 WRU。所需 WRU 的总数取决于行大小。例如,如果行大小为 2 KB,则需要 2 个 WRU 才能执行一个写入请求。

有关支持的一致性级别的信息,请参阅Amazon Keyspaces (for Apache Cassandra) 中支持的 Apache Cassandra 一致性级别

峰值流量和扩展属性

使用按需容量模式的 Amazon Keyspaces 表会自动适应应用程序的流量。按需容量模式会即时在表中承受之前双倍的峰值流量。例如,您的应用程序流量模式可能在每秒 5,000 到 10,000 次 LOCAL_QUORUM 读取之间变化,其中每秒 10,000 次读取是以前的流量峰值。使用这种模式,按需容量模式可即时容纳最高每秒 20,000 次读取的持续流量。如果应用程序承受每秒 20,000 次读取的流量,则该峰值将成为新的之前峰值,从而使后续流量高达每秒 40,000 次读取。

如果您在一个表上需要的流量是前一个峰值的两倍以上,则随着流量的增加,Amazon Keyspaces 自动分配更多容量。这有助于确保您的表具有足够的吞吐容量来处理额外的请求。但是,如果您在 30 分钟内超过前一个峰值的两倍,则可能会出现吞吐容量不足错误。例如,假设您的应用程序流量模式在每秒 5,000 到 10,000 个强一致性读取之间变化,而上一次达到的流量峰值为每秒 20,000 次读取。在这种情况下,服务建议您在将流量推动到每秒 40,000 次读取之前,至少将流量增长的时间间隔 30 分钟。

要了解有关账户的默认配额以及如何增加此配额的更多信息,请参阅 Amazon Keyspaces (for Apache Cassandra) 的配额

按需容量模式的最初吞吐量

如果您在启用按需容量模式的情况下创建了新表,或者首次将现有表切换为按需容量模式,则该表将具有以下之前峰值设置,即使该表之前尚未使用按需容量模式提供流量也是如此。

  • 在按需容量模式下新创建的表:先前峰值为 2,000 个 WRU 或 6,000 个 RRU。您可以立即将以前的峰值翻倍。这样,新创建的按需表可以提供最高 4,000 个 WRU 或 12,000 个RRU,或者两者的任意线性组合。

  • 现有表切换为按需容量模式:先前峰值是为该表先前预置的 WCU 和 RCU 的一半,或者是按需容量模式的新建表的设置,以较高者为准。

预置的吞吐容量模式

如果您选择预置的吞吐容量 模式,则指定您的应用程序需要的每秒读取和写入次数。这有助于您管理 Amazon Keyspaces 使用量,使其保持在或低于定义的请求速率以优化价格并保持可预测性。要详细了解预置吞吐量的自动扩展,请参阅使用 Application Auto Scaling 管理 Amazon Keyspaces 吞吐容量

如果满足以下任意条件,则预置的吞吐容量模式是很好的选项:

  • 您具有可预测的应用程序流量。

  • 您​运行流量比较稳定或逐渐增加的应用程序。

  • 您可以预测容量要求以优化价格。​

读取容量单位和写入容量单位

对于预置的吞吐容量模式表,您可以按读取容量单位 (RCU) 和写入容量单位 (WCU) 指定吞吐容量:

  • 对于大小不超过 4 KB 的行,一个 RCU 表示每秒一个 LOCAL_QUORUM 读取操作或每秒两个 LOCAL_ONE 读取操作。如果您需要读取大于 4 KB 的行,则读取操作将使用额外的 RCU。所需的 RCU 总数取决于行大小,以及要使用 LOCAL_QUORUM 还是 LOCAL_ONE 读取。例如,如果您的行大小为 8 KB,则需要 2 个 RCU 来维持每秒一个 LOCAL_QUORUM 读取;如果选择 LOCAL_ONE 读取,则需要 1 个 RCU。

  • 一个 WCU 表示对大小不超过 1 KB 的行每秒一次写入。所有写入操作都使用 LOCAL_QUORUM 一致性,使用轻量级事务 (LWT) 不收取额外费用。如果需要写入大于 1 KB 的行,则写入操作将使用额外的 WCU。所需 WCU 的总数取决于行大小。例如,如果您的行大小为 2 KB,则您需要 2 个 WCU 来维持每秒一个写入请求。

如果您的应用程序读取或写入较大的行(最大为 Amazon Keyspaces 的行大小上限 1 MB),它将消耗更多的容量单位。例如,假设您创建了具有 6 个 RCU 和 6 个 WCU 的预置表。使用这些设置,您的应用程序可以执行以下操作:

  • 执行每秒最高 24 KB 的 LOCAL_QUORUM 读取(4 KB × 6 个 RCU)。

  • 执行最高每秒 48 KB 的 LOCAL_ONE 读取(读取吞吐量的两倍)。

  • 写入最高每秒 6 KB(1 KB × 6 个 WCU)。

预置的吞吐量 是应用程序可以从表消耗的最大吞吐容量。如果您的应用程序超出了预置的吞吐容量,则可能会发现容量不足错误。例如,没有足够的吞吐容量的请求会失败,出现 HTTP 400 代码 (Bad Request) 和 ProvisionedThroughputExceededException。您可以使用 AWS 管理控制台 监视预置和实际吞吐量,并在必要时修改吞吐量设置。

要了解有关账户的默认配额以及如何增加此配额的更多信息,请参阅 Amazon Keyspaces (for Apache Cassandra) 的配额

管理和查看容量模式

您可以在 Amazon Keyspaces 系统键空间中查询系统表,以查看有关表的容量模式信息。您还可以查看表使用的是按需吞吐容量模式还是预置吞吐容量模式。如果表配置为预置吞吐量模式,您会看到为表预置的吞吐容量。

示例

SELECT * from system_schema_mcs.tables where keyspace_name = 'mykeyspace' and table_name = 'mytable';

使用按需容量模式配置的表返回以下内容。

{ 'capacity_mode': { 'last_update_to_pay_per_request_timestamp': '1579551547603', 'throughput_mode': 'PAY_PER_REQUEST' } }

使用预置吞吐容量模式配置的表将返回以下内容。

{ 'capacity_mode': { 'last_update_to_pay_per_request_timestamp': '1579048006000', 'read_capacity_units': '5000', 'throughput_mode': 'PROVISIONED', 'write_capacity_units': '6000' } }

last_update_to_pay_per_request_timestamp 值以毫秒为单位。

要更改表的预置吞吐容量,请使用 ALTER TABLE

更改容量模式时的注意事项

当您将表从预置的容量模式切换到按需容量模式时,Amazon Keyspaces 会对表和分区的结构进行若干更改。此过程可能耗时数分钟。在切换期间,您的表将提供与先前预置的 WCU 和 RCU 数量相一致的吞吐量。

当您从按需容量模式切换回预置的容量模式时,表将提供与表设置为按需容量模式时达到的先前峰值一致的吞吐量。

注意

您可以每 24 小时在读/写容量模式之间切换一次。