监控 AWS Lambda Python 函数编辑

Python APM 代理可与 AWS Lambda 一起使用,以监控 AWS Lambda 函数的执行。

Note: The Centralized Agent Configuration on the Elasticsearch APM currently does NOT support AWS Lambda.

先决条件编辑

您需要一个 APM 服务器来发送 APM 数据。如果您尚未设置,请按照 APM 快速入门 操作。为了获得最佳性能,我们建议在与您的 AWS Lambda 函数相同的 AWS 区域的 Elastic Cloud 上设置 APM。

步骤 1:选择 AWS 区域和架构编辑

此版本表 中选择适用于 APM Lambda 扩展层的正确 ARN。

此外,从 此版本表 中选择适用于 APM 代理层的正确 ARN。

选择 Lambda 函数的 AWS 区域和架构。本文档将根据您的选择进行更新。
区域
架构

选择的AWS 区域架构必须与 AWS Lambda 函数的 AWS 区域和架构匹配!

步骤 2:将 APM 层添加到您的 Lambda 函数编辑

Elastic APM AWS Lambda 扩展和 Python APM 代理都作为 AWS Lambda 层 添加到您的 Lambda 函数。因此,您需要将相应的层 ARN(标识符)添加到您的 Lambda 函数。

要通过 AWS 管理控制台将层添加到您的 Lambda 函数

  1. 在 AWS 管理控制台中导航到您的函数
  2. 滚动到“层”部分,然后单击“添加层”按钮 AWS 控制台中层配置部分的图像
  3. 选择“指定 ARN”单选按钮
  4. 将 Elastic APM AWS Lambda 扩展层和 APM 代理层的以下 ARN 复制并粘贴到“指定 ARN”文本输入框中
    APM 扩展层
    EXTENSION_ARN
    APM 代理层
    AGENT_ARN 在 AWS 控制台中选择层的图像
  5. 单击“添加”按钮

步骤 3:在 AWS Lambda 上配置 APM编辑

Elastic APM AWS Lambda 扩展和 APM Python 代理是通过 AWS Lambda 函数上的环境变量配置的。

对于最小配置,您将需要APM 服务器 URL 来设置 APM 数据的目标,以及一个APM 密钥令牌。如果您希望使用 APM API 密钥 而不是 APM 密钥令牌,请在以下配置中使用 ELASTIC_APM_API_KEY 环境变量而不是 ELASTIC_APM_SECRET_TOKEN

对于生产环境,我们建议 使用 AWS Secrets Manager 来存储您的 APM 身份验证密钥,而不是在环境变量中以纯文本形式提供密钥值。

要通过 AWS 管理控制台配置 APM

  1. 在 AWS 管理控制台中导航到您的函数
  2. 单击“配置”选项卡
  3. 单击“环境变量
  4. 添加以下必需变量
AWS_LAMBDA_EXEC_WRAPPER       = /opt/python/bin/elasticapm-lambda  # use this exact fixed value
ELASTIC_APM_LAMBDA_APM_SERVER = <YOUR-APM-SERVER-URL>              # this is your APM Server URL
ELASTIC_APM_SECRET_TOKEN      = <YOUR-APM-SECRET-TOKEN>            # this is your APM secret token
ELASTIC_APM_SEND_STRATEGY     = background                         

Python environment variables configuration section in AWS Console

ELASTIC_APM_SEND_STRATEGY 定义何时将 APM 数据发送到您的 Elastic APM 后端。为了减少 lambda 函数的执行时间,我们建议在生产环境中使用稳定负载场景的 background 策略。

您可以选择 微调 Python 代理Elastic APM AWS Lambda 扩展的配置

就是这样。按照上述步骤操作后,您就可以开始了!从现在开始,您的 Lambda 函数调用将被跟踪。将捕获对 支持的技术 的跨度。您还可以使用 capture_span 来捕获自定义跨度,并且可以使用 get_client 来检索用于捕获异常/消息的 Client 对象。