AWS cloudwatch监控指标订阅sns,sns触发lambda流程
以 wuerp里面的devops rds为例
lambda
创建lambda函数 AWS-SNS-OPS
在Linux服务器上创建一个文件夹 aws-sns-ops
mkdir /usr/local/aws-sns-ops
cd /usr/local/aws-sns-ops
pip install requests -t .
touch lambda_function.py
lambda_function.py
import json
import requests
def lambda_handler(event, context):
info = ''
message = str(event['Records'][0]['Sns']['Message'])
message=json.loads(message)
for k,v in dict.items(message):
info = info + k + ': '+str(v)+'\n'
info = "Asia AWS Events:\n" + info
headers = {"Content-Type": "text/plain"}
data = {
"msgtype": "text",
"text": {"content": str(info)}
}
ret = requests.post(
url='企业微信机器人id',
headers=headers,
json=data
)
print(ret.text)
return {
'statusCode': 200,
'body': json.dumps(ret.text)
}
对文件打包上传至lambda
cd ..
zip -r aws-sns-ops.zip aws-sns-ops
aws lambda update-function-code --function-name AWS-SNS-OPS --zip-file fileb://sns.zip
创建SNS
创建sns主题 OPS-SNS
创建订阅 lambda 选择自己创建的lambda函数 AWS-SNS-OPS
登录cloudwatch
选择 指标 -> 搜索devops为名字的指标 -> 选择 RDS -> 每个数据库的指标 -> CPUUtilization -> 汇成图表的指标 -> 点击操作 创建警报
选择想要监控的阈值(假设CPU大于80 5分钟时间)
实现效果
现在就达到了当我们监控的rds数据库的cloudwatch的CPU指标达到了我们设置的80%,持续了5分钟以上,会触发我们订阅的sns消息,SNS触发绑定的lambda实现对企业微信的发消息
注 这个event是监控的报警event,这个脚本对立面的信息进行了提取,使这个内容更加详细,效果如下