使用 AWS CDK 创建的 AWS Lambda@Edge 无法将日志发送至 CloudWatch

0

【以下的问题经过翻译处理】 我创建了一个简单的 Lambda@Edge 函数,如下所示。

'use strict';

exports.handler =  async function(event, context, callback) {
    const cf = event.Records[0].cf;
    console.log('Record: ', JSON.stringify(cf, null, 2));
    console.log('Context: ', JSON.stringify(context, null, 2));
    console.log('Request: ', JSON.stringify(cf.request, null, 2));
    callback(null, cf.request);
}

我使用 AWS CDKv2 experimental EdgeFunction 进行了部署,如下所示

const edgeFunction = new cloudfront.experimental.EdgeFunction(this, 'EdgeFunction', {
            runtime: Runtime.NODEJS_14_X,
            handler: 'index.handler',
            code: Code.fromAsset(path.join(__dirname, '../../../../lambda/ssr2')),
        });

我还将其设置为 Distribution (分配)的边缘函数

const distribution = new Distribution(this, 'Distribution', {
            defaultBehavior: {
                origin,
                cachePolicy: CachePolicy.CACHING_DISABLED,
                viewerProtocolPolicy: ViewerProtocolPolicy.REDIRECT_TO_HTTPS,
                edgeLambdas: [
                    {
                        functionVersion: edgeFunction.currentVersion,
                        eventType: LambdaEdgeEventType.VIEWER_REQUEST,
                    }
                ]
            },

但当我尝试向 Distribution 发送请求时,日志却没有显示任何内容。

我检查了权限,该角色已经拥有权限

Allow: logs:CreateLogGroup
Allow: logs:CreateLogStream
Allow: logs:PutLogEvents

我希望将该函数日志写入 CloudWatch。我哪里做错了?

更新 1

以下是角色文件:

{
    "sdkResponseMetadata": null,
    "sdkHttpMetadata": null,
    "partial": false,
    "permissionsBoundary": null,
    "policies": [
      {
        "arn": "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole",
        "document": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Effect": "Allow",
              "Action": [
                "logs:CreateLogGroup",
                "logs:CreateLogStream",
                "logs:PutLogEvents"
              ],
              "Resource": "*"
            }
          ]
        },
        "id": "ANPAJNCQGXC425412345",
        "name": "AWSLambdaBasicExecutionRole",
        "type": "managed"
      }
    ],
    "resources": {
      "logs": {
        "service": {
          "icon": "",
          "name": "Amazon CloudWatch Logs"
        },
        "statements": [
          {
            "action": "logs:CreateLogGroup",
            "effect": "Allow",
            "resource": "*",
            "service": "logs",
            "source": {
              "index": "0",
              "policyName": "AWSLambdaBasicExecutionRole",
              "policyType": "managed"
            }
          },
          {
            "action": "logs:CreateLogStream",
            "effect": "Allow",
            "resource": "*",
            "service": "logs",
            "source": {
              "index": "0",
              "policyName": "AWSLambdaBasicExecutionRole",
              "policyType": "managed"
            }
          },
          {
            "action": "logs:PutLogEvents",
            "effect": "Allow",
            "resource": "*",
            "service": "logs",
            "source": {
              "index": "0",
              "policyName": "AWSLambdaBasicExecutionRole",
              "policyType": "managed"
            }
          }
        ]
      }
    },
    "roleName": "MyProject-EdgeFunctionFnServiceRoleC7B72E4-1DV3AZXP558ZS",
    "trustedEntities": [
      "lambda.amazonaws.com",
      "edgelambda.amazonaws.com"
    ]
  }

我刚刚尝试了使用 Lambda 面板中的测试。所有测试都将日志发送到 CloudWatch。但是,当我向 CloudFront 发送请求时,它没有发送任何内容。

更新 2 我刚从 StackOverflows 发现,日志不是集中存储的,而是分布在各个区域的。如下所示

/aws/lambda/us-east-1.MyProject-EdgeFunctionFn44308ADF-loJeFwXXzTOm

因此,我需要在 CloudFront 面板中打开它,而不是从 Lambda 面板中打开它。我在任何 AWS 文档中都没有找到相关信息。

参考

https://aws.amazon.com/id/blogs/networking-and-content-delivery/aggregating-lambdaedge-logs/

<https://stackoverflow.com/questions/66949758/serverless-aws-lambdaedge-how-to-debug#:~:text=Go%20to%20CloudWatch%20and%20search,%2D%3E%20Lambda%40Edge%20Errors %20>。

profile picture
专家
已提问 5 个月前49 查看次数
1 回答
0

【以下的回答经过翻译处理】 我以前在使用 Lambda@Edge 日志时也遇到过这个问题。日志会打印到用于接收内容的任何区域的 CloudWatch 日志组中。由于 Lambda@Edge 在所有使用的边缘位置进行复制,因此虽然您处理的是一个 Lambda 函数,但实际上您正在处理多达几十个 Lambda@Edge 函数。因此,请查看所有靠近您所在位置的区域中的 CloudWatch 日志组,查找边缘 Lambda 的日志组。

要在 CloudFront 面板中找到该选项,请访问 Telemetry->Monitoring,选择 Lambda@Edge 选项卡,选择相应的 lambda 版本,然后在右上角会出现一个名为 View Function Logs(查看函数日志)的下拉菜单,在那里您可以看到所有提供日志的区域。

profile picture
专家
已回答 5 个月前

您未登录。 登录 发布回答。

一个好的回答可以清楚地解答问题和提供建设性反馈,并能促进提问者的职业发展。

回答问题的准则