1 创建一个lamda函数,运行时选择python
data:image/s3,"s3://crabby-images/58488/58488e416aba620e321121c29e744a2d32e644b6" alt=""
贴入下面代码并点击deploy
import json
def lambda_handler(event, context):
# 打印接收到的事件
print("Received event: " + json.dumps(event, indent=2))
# 可以在这里添加其他处理逻辑
# 例如,提取某些信息并进行处理
# 返回响应
return {
'statusCode': 200,
'body': json.dumps({'message': 'Event processed successfully'})
}
data:image/s3,"s3://crabby-images/290ca/290caab0b0b875f6cde4ae7018aa51824c440afc" alt=""
2 创建事件总线
data:image/s3,"s3://crabby-images/5d4bc/5d4bc0415d5f02fbcc700894b0479919119cb79f" alt=""
名字写上就可以保存了
data:image/s3,"s3://crabby-images/5534a/5534ab0ca60bfed9f39a2b30502fa9ec357041bd" alt=""
在总线下进行规则创建
data:image/s3,"s3://crabby-images/daa71/daa71bcddeebab47cc7e647696af2a472faed524" alt=""
Event 有三种来源
data:image/s3,"s3://crabby-images/52c87/52c87f1a1f0ed1db9ce0fb46c564f8e0eb7b84ed" alt=""
AWS事件,合作伙伴事件,输入自己的
通过选择不同的事件来源,后面我们可以通过事件构造去匹配这种格式的event
data:image/s3,"s3://crabby-images/0d2a9/0d2a9e7c66402fbf030d1191cf80a342dfef8fad" alt=""
比如选择自定义
data:image/s3,"s3://crabby-images/de37c/de37cad3ca69ef3f820ebfeec7e044d01a47ca04" alt=""
在事件模式填入对应json然后点击测试,绿色说明测试成功可以匹配到该event
data:image/s3,"s3://crabby-images/7bee8/7bee8a96305cdb79fc2cc33794ed8bc76937024e" alt=""
{
"source": [{
"wildcard": "*"
}],
"detail-type": [{
"wildcard": "*"
}],
"detail": {
"EventSource": [{
"wildcard": "*"
}],
"eventSource": [{
"wildcard": "*"
}],
"key1": [{
"wildcard": "*"
}]
}
}
在本地准备python 代码, 其中EventBusName 指定event送到哪个总线里进行处理
import boto3
import json
from datetime import datetime
# 创建 EventBridge 客户端
client = boto3.client('events')
# 定义事件
event = {
'Source': 'my.custom.source.test.bili.mysql', # 事件来源
'DetailType': 'AWS API Call via CloudTrail good or bad', # 事件类型
'Detail': json.dumps({
"EventSource": "bili.custom.source",
"eventSource": "bili.custom.source",
"key1": "value1"
}),
'EventBusName': 'event-bus', # 指定事件总线
'Time': datetime.utcnow() # 事件时间,使用 UTC
}
# 发送事件
try:
response = client.put_events(
Entries=[
event
]
)
print("Event sent! Response:", response)
except Exception as e:
print("Error sending event:", e)
在lamda里添加监听器,选择evnetbridge-rule
data:image/s3,"s3://crabby-images/5e8e7/5e8e77efe39521f0363c8c819e06b220205bd1e8" alt=""
观察指标
总线的监控看收到的event 总数
data:image/s3,"s3://crabby-images/0cce6/0cce6d7fb2f2292f1365c56a85ba16a8e07a9dcf" alt=""
rule的监控看匹配到的event数
data:image/s3,"s3://crabby-images/975db/975dba2d16eb53396201d932b68474ad8221cda1" alt=""
cloudwatch里看lamda日志
data:image/s3,"s3://crabby-images/d4e69/d4e696b7ecf99fd3078fc86b2cf67f085099f5b7" alt=""
同理可以在lamda触发源上配置API gateway
data:image/s3,"s3://crabby-images/3970f/3970fc5a345b54ea7f9cad84df724aaba6b9ac63" alt=""
data:image/s3,"s3://crabby-images/442c6/442c6075226c521f9ef8b10f912f75dd0ddcf50e" alt=""
data:image/s3,"s3://crabby-images/1f332/1f332aae2893a8a7ce4367aa8a9ede415a98016e" alt=""
访问网关在这里
data:image/s3,"s3://crabby-images/24947/2494729c36e60a58a81f85f69486141f5758062c" alt=""
使用postman去请求
data:image/s3,"s3://crabby-images/d76ed/d76ed7fb259b43cd3a05d065b53611d9883c1343" alt=""
查看日志
data:image/s3,"s3://crabby-images/c38f6/c38f64d8d0878bcc0aa7ff1f8cd34210e8dbd249" alt=""