777.sh
1.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#!/bin/bash
echo "=== 启用 API Gateway 详细日志 ==="
API_ID="o7epe60qzf"
STAGE_NAME="prod"
LOG_GROUP="/aws/apigateway/$API_ID"
echo "1. 创建 CloudWatch 日志组:"
aws logs create-log-group --log-group-name "$LOG_GROUP" 2>/dev/null || echo "日志组已存在"
echo "2. 启用访问日志:"
aws apigateway update-stage \
--rest-api-id $API_ID \
--stage-name $STAGE_NAME \
--patch-operations \
"op=replace,path=/accessLogSettings/destinationArn,value=arn:aws:logs:us-east-1:319998871902:log-group:$LOG_GOUP" \
"op=replace,path=/accessLogSettings/format,value='\$context.identity.sourceIp \$context.identity.caller \$context.identity.user [\$context.requestTime] \"\$context.httpMethod \$context.resourcePath \$context.protocol\" \$context.status \$context.responseLength \$context.requestId \$context.integrationErrorMessage \$context.error.message \$context.error.responseType'"
echo "3. 启用详细日志级别:"
aws apigateway update-stage \
--rest-api-id $API_ID \
--stage-name $STAGE_NAME \
--patch-operations \
"op=replace,path=/*/*/logging/dataTrace,value=true" \
"op=replace,path=/*/*/logging/loglevel,value=INFO"
echo "✅ 详细日志已启用"
echo ""
echo "4. 重新测试以生成日志:"
TEST_URL="https://${API_ID}.execute-api.us-east-1.amazonaws.com/${STAGE_NAME}/health"
echo "测试: $TEST_URL"
for i in {1..3}; do
echo "测试 $i: $(curl -s -o /dev/null -w "%{http_code}" "$TEST_URL")"
sleep 2
done
echo ""
echo "5. 检查 CloudWatch 日志流:"
sleep 10
aws logs describe-log-streams \
--log-group-name "$LOG_GROUP" \
--order-by LastEventTime \
--descending \
--max-items 3 \
--query 'logStreams[*].{LogStreamName:logStreamName, LastEventTimestamp:lastEventTimestamp}' \
--output table