Serverless metrics and events for Valkey and Redis OSS
ElastiCache offers a wide variety of metrics and events for monitoring when working with serverless caches. This includes CloudWatch metrics, command level metrics, and event logs which can be ingested via Amazon EventBridge.
Topics
Serverless cache metrics
The AWS/ElastiCache
namespace includes the following CloudWatch metrics for your Valkey or Redis OSS serverless caches.
Metric codes for Valkey or Redis OSS
Metric | Description | Unit |
---|---|---|
BytesUsedForCache |
The total number of bytes used by the data stored in your cache. |
Bytes |
ElastiCacheProcessingUnits |
The total number of ElastiCacheProcessingUnits (ECPUs) consumed by the requests executed on your cache |
Count |
SuccessfulReadRequestLatency |
Latency of successful read requests. |
Microseconds |
SuccessfulWriteRequestLatency |
Latency of successful write requests |
Microseconds |
TotalCmdsCount |
Total count of all commands executed on your cache |
Count |
CacheHitRate |
Indicates the hit rate of your cache. This is calculated
using |
Percent |
CacheHits |
The number of successful read-only key lookups in the cache. |
Count |
CurrConnections |
The number of client connections to your cache. |
Count |
ThrottledCmds |
The number of requests that were throttled by ElastiCache because the workload was scaling faster than ElastiCache can scale. |
Count |
NewConnections |
The total number of connections that have been accepted by the server during this period. |
Count |
CurrItems |
The number of items in the cache. |
Count |
CurrVolatileItems |
The number of items in the cache with TTL. |
Count |
NetworkBytesIn |
Total bytes transferred in to cache |
Bytes |
NetworkBytesOut |
Total bytes transferred out of cache |
Bytes |
Evictions |
The count of keys evicted by the cache |
Count |
IamAuthenticationExpirations |
The total number of expired IAM-authenticated Valkey or Redis OSS connections. You can find more information about Authenticating with IAM in the user guide. |
Count |
IamAuthenticationThrottling |
The total number of throttled IAM-authenticated Valkey or Redis OSS AUTH or HELLO requests. You can find more information about Authenticating with IAM in the user guide. |
Count |
KeyAuthorizationFailures |
The total number of failed attempts by users to access keys they don’t have permission to access. We suggest setting an alarm on this to detect unauthorized access attempts. |
Count |
AuthenticationFailures |
The total number of failed attempts to authenticate to Valkey or Redis OSS using the AUTH command. We suggest setting an alarm on this to detect unauthorized access attempts. |
Count |
CommandAuthorizationFailures |
The total number of failed attempts by users to run commands they don’t have permission to call. We suggest setting an alarm on this to detect unauthorized access attempts. |
Count |
Command level metrics
ElastiCache also emits the following command level metrics. For each command type, ElastiCache emits the total count of commands and the number of ECPUs consumed by that command type.
Metric | Description | Unit |
---|---|---|
EvalBasedCmds |
The number of get commands the cache has received. |
Count |
EvalBasedCmdsECPUs |
ECPUs consumed by eval-based commands. |
Count |
GeoSpatialBasedCmds |
The total number of commands for geospatial-based commands. This is derived from the Valkey or Redis OSS commandstats statistic. It's derived by summing all of the geo type of commands: geoadd, geodist, geohash, geopos, georadius, and georadiusbymember. |
Count |
GeoSpatialBasedCmdsECPUs |
ECPUs consumed by geospatial-based commands. |
Count |
GetTypeCmds |
The total number of read-only type commands. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the read-only type commands (get, hget, scard, lrange, and so on.) |
Count |
GetTypeCmdsECPUs |
ECPUs consumed by read commands. |
Count |
HashBasedCmds |
The total number of commands that are hash-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more hashes (hget, hkeys, hvals, hdel, and so on). |
Count |
HashBasedCmdsECPUs |
ECPUs consumed by hash-based commands. |
Count |
HyperLogLogBasedCmds |
The total number of HyperLogLog-based commands. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the pf type of commands (pfadd, pfcount, pfmerge, and so on.). |
Count |
HyperLogLogBasedCmdsECPUs |
ECPUs consumed by HyperLogLog-based commands. |
Count |
JsonBasedCmds |
The total number of JSON commands, including both read and write commands. This is derived from the Valkey or Redis OSS commandstats statistic by summing all JSON commands that act upon JSON keys. |
Count |
JsonBasedCmdsECPUs |
ECPUs consumed by all JSON commands, including both read and write commands. |
Count |
JsonBasedGetCmds |
The total number of JSON read-only commands. This is derived from the Valkey or Redis OSS commandstats statistic by summing all JSON read commands that act upon JSON keys. |
Count |
JsonBasedGetCmdsECPUs |
ECPUs consumed by JSON read-only commands. |
Count |
JsonBasedSetCmds |
The total number of JSON write commands. This is derived from the Valkey or Redis OSS commandstats statistic by summing all JSON write commands that act upon JSON keys. |
Count |
JsonBasedSetCmdsECPUs |
ECPUs consumed by JSON write commands. |
Count |
KeyBasedCmds |
The total number of commands that are key-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more keys across multiple data structures (del, expire, rename, and so on.). |
Count |
KeyBasedCmdsECPUs |
ECPUs consumed by key-based commands. |
Count |
ListBasedCmds |
The total number of commands that are list-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more lists (lindex, lrange, lpush, ltrim, and so on). |
Count |
ListBasedCmdsECPUs |
ECPUs consumed by list-based commands. |
Count |
NonKeyTypeCmds |
The total number of commands that are not key-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that do not act upon a key, for example, acl, dbsize or info. |
Count |
NonKeyTypeCmdsECPUs |
ECPUs consumed by non-key-based commands. |
Count |
PubSubBasedCmds |
The total number of commands for pub/sub functionality. This is derived from the Valkey or Redis OSS commandstatsstatistics by summing all of the commands used for pub/sub functionality: psubscribe, publish, pubsub, punsubscribe, ssubscribe, sunsubscribe, spublish, subscribe, and unsubscribe. |
Count |
PubSubBasedCmdsECPUs |
ECPUs consumed by pub/sub-based commands. |
Count |
SetBasedCmds |
The total number of commands that are set-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more sets (scard, sdiff, sadd, sunion, and so on). |
Count |
SetBasedCmdsECPUs |
ECPUs consumed by set-based commands. |
Count |
SetTypeCmds |
The total number of write types of commands. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the mutative types of commands that operate on data (set, hset, sadd, lpop, and so on.) |
Count |
SetTypeCmdsECPUs |
ECPUs consumed by write commands. |
Count |
SortedSetBasedCmds |
The total number of commands that are sorted set-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more sorted sets (zcount, zrange, zrank, zadd, and so on). |
Count |
SortedSetBasedCmdsECPUs |
ECPUs consumed by sorted-based commands. |
Count |
StringBasedCmds |
The total number of commands that are string-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more strings (strlen, setex, setrange, and so on). |
Count |
StringBasedCmdsECPUs |
ECPUs consumed by string-based commands. |
Count |
StreamBasedCmds |
The total number of commands that are stream-based. This is derived from the Valkey or Redis OSS commandstats statistic by summing all of the commands that act upon one or more streams data types (xrange, xlen, xadd, xdel, and so on). |
Count |
StreamBasedCmdsECPUs |
ECPUs consumed by stream-based commands. |
Count |
Serverless cache events
ElastiCache logs events that relate to your serverless cache. This information includes the date and time of the event,
the source name and source type of the event, and a description of the event. You can easily retrieve events from the log
using the ElastiCache console, the AWS CLI describe-events command, or the ElastiCache API action DescribeEvents
.
You can choose to monitor, ingest, transform, and act on ElastiCache events using Amazon EventBridge. Learn more in the Amazon EventBridge getting started guide.
Viewing ElastiCache events (Console)
To view events using the ElastiCache console:
Sign in to the AWS Management Console and open the ElastiCache console at https://console.aws.amazon.com/elasticache/
To see a list of all available events, in the navigation pane, choose Events.
On the Events screen each row of the list represents one event and displays the event source, the event type, the GMT time of the event, and a description of the event. Using the Filter you can specify whether you want to see all events, or just events of a specific type in the event list.
Viewing ElastiCache events (AWS CLI)
To generate a list of ElastiCache events using the AWS CLI, use the command describe-events. You can use optional parameters to control the type of events listed, the time frame of the events listed, the maximum number of events to list, and more.
The following code lists up to 40 serverless cache events.
aws elasticache describe-events --source-type serverless-cache --max-items 40
The following code lists all events for serverless caches for the past 24 hours (1440 minutes).
aws elasticache describe-events --source-type serverless-cache --duration 1440
Serverless Events
This section documents the different types of events that you may receive for your serverless caches.
Serverless Cache Creation Events
Detail-Type | Description | Unit | Source | Message |
---|---|---|---|---|
Cache created |
Cache arn |
creation |
serverless-cache |
Cache <cache-name> is created and ready to use. |
Cache created |
Cache arn Snapshot arn |
creation |
serverless-cache |
Cache <cache-name> is created and data was restored from snapshot. Your cache is ready to use. |
Cache creation failed |
Cache arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. Insufficient free IP addresses to create VPC endpoint. |
Cache creation failed |
Cache arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. Invalid subnets provided in the request. |
Cache creation failed |
Cache arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. Quota limit reached for creating VPC endpoint. |
Cache creation failed |
Cache arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. You do not have permissions to create a VPC endpoint. |
Cache creation failed |
Cache arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. A user with an incompatible Valkey or Redis OSS version is present in user group <user-group-name>. |
Cache creation failed |
Cache arn Cache snapshot arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. The provided user group <user-group-name> does not exist. |
Cache creation failed |
Cache arn |
failure |
serverless-cache |
Failed to create cache <cache-name>. Data restoration from snapshot failed because <reason>. Failure reasons:
|
Serverless Cache Update Events (Valkey or Redis OSS)
Detail-Type | Resources list | Category | Source | Message |
---|---|---|---|---|
Cache updated |
Cache arn |
configuration change |
serverless-cache |
SecurityGroups updated for the cache <cache-name>. |
Cache updated |
Cache arn |
configuration change |
serverless-cache |
Tags updated for the cache <cache-name>. |
Cache updated failed |
Cache arn |
configuration change |
serverless-cache |
An update to the cache <cache-name> failed. A user with an incompatible Valkey or Redis OSS version is present in user group <user-group-name>. |
Cache updated failed |
Cache arn |
configuration change |
serverless-cache |
An update to the cache <cache-name> failed. SecurityGroups update failed. |
Cache updated failed |
Cache arn |
configuration change |
serverless-cache |
An update to the cache <cache-name> failed. SecurityGroups update failed because of insufficient permissions. |
Cache updated failed |
Cache arn |
configuration change |
serverless-cache |
An update to the cache <cache-name> failed. SecurityGroups update failed because the SecurityGroups are invalid. |
Serverless Cache Deletion Events (Valkey or Redis OSS)
Detail-Type | Resources list | Category | Source | Message |
---|---|---|---|---|
Cache deleted |
Cache arn |
deletion |
serverless-cache |
Cache <cache-name> was deleted. |
Serverless Cache Usage Limit Events (Valkey or Redis OSS)
Detail-Type | Description | Unit | Source | Message |
---|---|---|---|---|
Cache updated |
Cache arn |
configuration change |
serverless-cache |
Limits updated for the cache <cache-name>. |
Cache limit approaching |
Cache arn |
notification |
serverless-cache |
Slot <X> is using more than <Y>% of the per-slot limit of 32 GB. For example, Slot 10 is using more than 90% of the per-slot limit of 32 GB. |
Cache updated failed |
Cache arn |
failure |
serverless-cache |
A limit update to the cache <cache-name> failed because the cache was deleted. |
Cache updated failed |
Cache arn |
failure |
serverless-cache |
A limit update to the cache <cache-name> failed due to invalid configuration. |
Cache updated failed |
Cache arn |
failure |
serverless-cache |
A limit update to the cache <cache-name> failed because current cached data exceeds new limits. Please flush some data before applying the limits. |
Serverless Cache Snapshot Events (Valkey or Redis OSS)
Detail-Type | Resources-list | Category | Source | Message |
---|---|---|---|---|
Snapshot created |
Cache arn Snapshot arn |
creation |
serverless-cache-snapshot |
Snapshot <snapshot-name> created for cache <cache-name>. |
Snapshot creation failed |
Cache arn Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to create snapshot for cache <cache-name>. Snapshot <snapshot-name> creation failed with Customer Managed Key <key-id> <reason>. Failure reason messages:
|
Snapshot creation failed |
Cache arn Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to create snapshot for cache <cache-name>. Snapshot <snapshot-name> creation failed because <reason>. Default reason:
|
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket %s because ElastiCache does not have permissions to the bucket. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s' because there is already an object with the same name in the bucket. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s' because bucket owner account Id has changed. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s' because the S3 bucket is not accessible. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s' because the bucket is not accessible. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s' because bucket does not exist. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s' with source snapshot Customer Managed Key %s <reason>. |
Snapshot export failed |
Snapshot arn |
failure |
serverless-cache-snapshot |
Failed to export snapshot for cache <cache-name>. Could not export snapshot to bucket '%s'. |
Snapshot copy failed |
Snapshot arn-1 Snapshot arn-2 |
failure |
serverless-cache-snapshot |
Failed to copy snapshot <snapshot-name>. Could not copy snapshot '%s' to snapshot '%s' with source snapshot Customer Managed Key <key-id> <reason-name>. |
Snapshot copy failed |
Snapshot arn-1 Snapshot arn-2 |
failure |
serverless-cache-snapshot |
Failed to copy snapshot <snapshot-name>. Could not copy snapshot '%s' to snapshot '%s' with target snapshot Customer Managed Key '%s' '%s'. |
Self-designed cluster metrics and events for Valkey and Redis OSS
ElastiCache offers a wide variety of metrics and events for monitoring self-designed clusters when working with Valkey and Redis OSS . This includes host-level metrics, command level metrics, and event logs available via the AWS CLI and the Amazon Simple Notification Service (SNS).