777.sh 1.77 KB
#!/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