如何设置AWS Trusted Advisor警报以获取服务限制警告?

55次阅读
没有评论

问题描述

有用户希望在AWS Trusted Advisor的任何服务限制达到“WARN”或“ERROR”状态时,能够收到电子邮件通知。用户已经查阅了AWS的指南,并尝试与支持团队交流,但没有人能够实现这个目标。用户希望在Service Limits接近达到时,能够通过某种事件机制向DevOps团队发送电子邮件通知。用户愿意接受每周最多一次或者每天一次的检查频率。

解决方案

请注意以下操作可能因版本差异而有所不同,如有需要请先备份数据。

AWS Trusted Advisor提供了一种方式来轮询检查状态变化并获得状态更新的通知。你可以使用AWS CLI的support命令子集来实现这个目标。以下是一种可能的解决方案:

步骤1:安装AWS CLI

如果你还没有安装AWS CLI,可以按照官方文档的指引进行安装:Installing the AWS CLI

步骤2:轮询Trusted Advisor检查状态

在这个解决方案中,我们将使用AWS CLI来轮询Trusted Advisor检查状态的变化。

  1. 打开终端或命令提示符,执行以下命令来获取Trusted Advisor检查的状态:

bash
aws support describe-trusted-advisor-checks --language en

  1. 从返回的结果中,找到你希望监视的检查的唯一标识(check ID)。

  2. 使用以下命令来轮询特定检查的状态变化。假设你的检查ID是your-check-id,你可以用下面的命令进行轮询:

bash
while true; do
result=$(aws support describe-trusted-advisor-check-result --check-id your-check-id --language en)
status=$(echo "$result" | jq -r '.result.status')
if [ "$status" != "ok" ]; then
echo "Service Limit Status: $status"
# 在这里可以触发发送邮件或其他通知操作
fi
sleep 86400 # 每隔一天轮询一次,86400秒为一天的秒数
done

上述代码使用了jq工具来解析JSON数据,你需要先安装它。该代码会每隔一天(86400秒)轮询一次Trusted Advisor检查的状态。当状态不是”ok”时(即WARN或ERROR状态),你可以在注释的位置添加发送邮件或其他通知的操作。

这个解决方案可以通过轮询AWS Trusted Advisor的检查状态来实现检测服务限制的变化,并在达到限制时触发相应的通知。记得根据你的需求和环境对脚本进行适当的修改和调整。

其他选项

除了使用AWS CLI轮询检查状态,你还可以考虑其他自定义事件选项,或者结合Jenkins2和AWS CLI来实现类似的目标。在某些情况下,使用Jenkins2来发送Slack通知可能会更加方便。

注意: 对于某些选项,可能需要Business或Enterprise类型的AWS账户。了解更多详情可以查阅这个链接

希望上述解决方案能够帮助你实现在Service Limits接近达到时收到通知的需求。记得根据你的实际情况进行适当的调整和测试。

正文完