创建 CloudWatch 警报以监控 DynamoDB - Amazon DynamoDB
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

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

创建 CloudWatch 警报以监控 DynamoDB

您可以创建一个 CloudWatch 警报,在警报状态发生变化时发送 Amazon SNS 消息。警报会每隔一段时间 (由您指定) 监控一个指标,并根据相对于给定阈值的指标值每隔若干个时间段执行一项或多项操作。操作是一个发送到 Amazon SNS 主题或自动扩缩策略的通知。警报仅针对持续的状态变化调用操作。 CloudWatch 警报不会仅仅因为它们处于特定状态就调用操作;该状态必须已更改并保持了指定的时间段。

注意

创建 CloudWatch 警报时,您必须指定所有必需的维度,因为 CloudWatch 不会汇总缺失维度的指标。创建 CloudWatch警报时,创建缺少维度的警报不会导致错误。

有关 DynamoDB 中受支持的指标及其所需维度的列表,请参阅 查看 指标和维度

如何在占用整个读取容量之前收到通知?

  1. 创建 Amazon SNS 主题,arn:aws:sns:us-east-1:123456789012:capacity-alarm

    有关更多信息,请参阅设置 Amazon Simple Notification Service

  2. 创建告警。在此示例中,我们假设预置容量为五个读取容量单位。

    aws cloudwatch put-metric-alarm \ --alarm-name ReadCapacityUnitsLimitAlarm \ --alarm-description "Alarm when read capacity reaches 80% of my provisioned read capacity" \ --namespace AWS/DynamoDB \ --metric-name ConsumedReadCapacityUnits \ --dimensions Name=TableName,Value=myTable \ --statistic Sum \ --threshold 240 \ --comparison-operator GreaterThanOrEqualToThreshold \ --period 60 \ --evaluation-periods 1 \ --alarm-actions arn:aws:sns:us-east-1:123456789012:capacity-alarm
  3. 测试告警。

    aws cloudwatch set-alarm-state --alarm-name ReadCapacityUnitsLimitAlarm --state-reason "initializing" --state-value OK
    aws cloudwatch set-alarm-state --alarm-name ReadCapacityUnitsLimitAlarm --state-reason "initializing" --state-value ALARM
注意

如果 1 分钟(60 秒)内占用的读取容量为每秒至少 4 个单位(预置读取容量的 80% 为 5),将激活告警。因此 threshold 为 240 个读取容量单位(4 个单位/秒 * 60 秒)。更新读取容量后,应相应更新告警计算。可以通过 DynamoDB 控制台创建告警来避免此过程。这样将自动更新告警。

如何知道是否有任何请求超出表的预置吞吐量配额?

  1. 创建 Amazon SNS 主题,arn:aws:sns:us-east-1:123456789012:requests-exceeding-throughput

    有关更多信息,请参阅设置 Amazon Simple Notification Service

  2. 创建告警。

    aws cloudwatch put-metric-alarm \ --alarm-name RequestsExceedingThroughputAlarm\ --alarm-description "Alarm when my requests are exceeding provisioned throughput quotas of a table" \ --namespace AWS/DynamoDB \ --metric-name ThrottledRequests \ --dimensions Name=TableName,Value=myTable Name=Operation,Value=aDynamoDBOperation \ --statistic Sum \ --threshold 0 \ --comparison-operator GreaterThanThreshold \ --period 300 \ --unit Count \ --evaluation-periods 1 \ --treat-missing-data notBreaching \ --alarm-actions arn:aws:sns:us-east-1:123456789012:requests-exceeding-throughput
  3. 测试告警。

    aws cloudwatch set-alarm-state --alarm-name RequestsExceedingThroughputAlarm --state-reason "initializing" --state-value OK
    aws cloudwatch set-alarm-state --alarm-name RequestsExceedingThroughputAlarm --state-reason "initializing" --state-value ALARM

如何确定是否发生任何系统错误?

  1. 创建 Amazon SNS 主题,arn:aws:sns:us-east-1:123456789012:notify-on-system-errors

    有关更多信息,请参阅设置 Amazon Simple Notification Service

  2. 创建告警。

    aws cloudwatch put-metric-alarm \ --alarm-name SystemErrorsAlarm \ --alarm-description "Alarm when system errors occur" \ --namespace AWS/DynamoDB \ --metric-name SystemErrors \ --dimensions Name=TableName,Value=myTable Name=Operation,Value=aDynamoDBOperation \ --statistic Sum \ --threshold 0 \ --comparison-operator GreaterThanThreshold \ --period 60 \ --unit Count \ --evaluation-periods 1 \ --treat-missing-data breaching \ --alarm-actions arn:aws:sns:us-east-1:123456789012:notify-on-system-errors
  3. 测试告警。

    aws cloudwatch set-alarm-state --alarm-name SystemErrorsAlarm --state-reason "initializing" --state-value OK
    aws cloudwatch set-alarm-state --alarm-name SystemErrorsAlarm --state-reason "initializing" --state-value ALARM