Pre-warm an existing table for
on-demand capacity mode in Amazon Keyspaces
Amazon Keyspaces automatically scales storage partitions based on throughput, but for new tables or new throughput
peaks, it can take longer to allocate the required storage partitions. To insure that tables in on-demand and
provisioned capacity mode have enough storage partitions to support the sudden higher throughput, you can
pre-warm a new or existing table.
If you anticipate a spike in peak capacity for your table that is twice
as high as the previous peek withing the same 30 minutes, you can pre-warm the table
to the peak capacity of the expected spike.
To pre-warm an existing on-demand table
in Amazon Keyspaces, you can follow these steps. To pre-warm a new table, see Pre-warm a new table for
on-demand capacity mode in Amazon Keyspaces.
Before you get started, review your account and table quotas for provisioned
mode and adjust them as needed.
Next review the required waiting periods between changing capacity modes.
Note that you'll incur costs for the provisioned capacity until the table is back in on-demand mode.
- Console
-
How to pre-warm an existing table in on-demand mode
-
Sign in to the AWS Management Console, and open the Amazon Keyspaces console at https://console.aws.amazon.com/keyspaces/home.
-
Choose the table that you want to work with, and go to the Capacity tab.
In the Capacity settings section, choose Edit.
Under Capacity mode, change the table to
Provisioned capacity mode.
-
In the Read capacity section, deselect
Scale automatically.
Set the table's Provisioned capacity units to the expected peak value.
-
In the Write capacity section, choose the same settings
as defined in the previous step for read capacity, or configure capacity
values manually.
-
When the provisioned capacity settings are defined, choose
Save. After you save changes, the table's status shows as Updating...
until the capacity is provisioned. Note that for large tables, the pre-warming process can take some time,
because the data needs to be divided across partitions. During this time, you can continue to access
the table and expect the previously configured peak capacity to be available.
When the table's status turns to Active, you can switch the table back to
On-demand capacity mode.
- Cassandra Query Language (CQL)
-
Pre-warm an existing table for on-demand mode using CQL
-
Change the table's capacity mode to PROVIOSIONED
and configure the read capacity
and write capacity based on your expected peak values.
ALTER TABLE catalog.book_awards WITH CUSTOM_PROPERTIES={'capacity_mode':{'throughput_mode': 'PROVISIONED', 'read_capacity_units': 18000, 'write_capacity_units': 6000}};
Confirm that the table is active. The following statement is an example.
SELECT * from system_schema_mcs.tables where keyspace_name = 'catalog' and table_name = 'book_awards';
When the table's status is ACTIVE
, you can use the following statement to change
the capacity mode of the table to on-demand mode by setting the throughput mode to PAY_PER_REQUEST
.
The following statement is an example of this.
ALTER TABLE catalog.book_awards WITH CUSTOM_PROPERTIES={'capacity_mode':{'throughput_mode': 'PAY_PER_REQUEST'}};
You can use the following statement to confirm that the table is now in on-demand mode and see the
table's status.
SELECT * from system_schema_mcs.tables where keyspace_name = 'catalog' and table_name = 'book_awards';
- CLI
-
Pre-warm an existing table for on-demand mode using the AWS CLI
-
Change the table's capacity mode to PROVIOSIONED
and configure the read capacity
and write capacity based on your expected peak values. The following command is an example of this.
aws keyspaces update-table --keyspace-name catalog --table-name book_awards
\--capacity-specification throughputMode=PROVISIONED,readCapacityUnits=18000,writeCapacityUnits=6000
Confirm that the status of the table is active and that the capacity has been provisioned. You can use the following statement.
aws keyspaces get-table --keyspace-name catalog --table-name book_awards
-
When the table's status is ACTIVE
and the capacity has been provisioned,
you can use the following statement to change
the capacity mode of the table to on-demand mode by setting the throughput mode to PAY_PER_REQUEST
.
The following statement is an example of this.
aws keyspaces update-table --keyspace-name catalog --table-name book_awards
\--capacity-specification throughputMode=PAY_PER_REQUEST
You can use the following statement to confirm that the table is now in on-demand mode and see the
table's status.
aws keyspaces get-table --keyspace-name catalog --table-name book_awards
When the table is active in on-demand capacity mode,
it's prepared to handle a similar throughput capacity as before in provisioned capacity mode.