在 AWS Lambda 中检测 Go 代码
Lambda 与 AWS X-Ray 集成,以帮助您跟踪、调试和优化 Lambda 应用程序。您可以在某个请求遍历应用程序中的资源(其中可能包括 Lambda 函数和其他 AWS 服务)时,使用 X-Ray 跟踪该请求。
要将跟踪数据发送到 X-Ray,您可以使用以下两个软件开发工具包 (SDK) 库之一:
-
适用于 OpenTelemetry 的 AWS 发行版 (ADOT)
– 一种安全、可供生产、支持 AWS 的 OpenTelemetry (OTel) SDK 的分发版本。 -
适用于 Go 的 AWS X-Ray 软件开发工具包 – 用于生成跟踪数据并将其发送到 X-Ray 的 SDK。
每个开发工具包均提供了将遥测数据发送到 X-Ray 服务的方法。然后,您可以使用 X-Ray 查看、筛选和获得对应用程序性能指标的洞察,从而发现问题和优化机会。
重要
X-Ray 和 Powertools for AWS Lambda SDK 是 AWS 提供的紧密集成的分析解决方案的一部分。ADOT Lambda Layers 是全行业通用的跟踪分析标准的一部分,该标准通常会收集更多数据,但可能不适用于所有使用案例。您可以使用任一解决方案在 X-Ray 中实现端到端跟踪。要了解有关如何在两者之间进行选择的更多信息,请参阅在 AWS Distro for Open Telemetry 和 X-Ray 开发工具包之间进行选择。
Sections
使用 ADOT 分析您的 Go 函数
ADOT 提供完全托管式 Lambda 层,这些层使用 OTel SDK,将收集遥测数据所需的一切内容打包起来。通过使用此层,您可以在不必修改任何函数代码的情况下,对您的 Lambda 函数进行分析。您还可以将您的层配置为对 OTel 进行自定义初始化。有关更多信息,请参阅 ADOT 文档中的适用于 Lambda 上的 ADOT 收集器的自定义配置
对于 Go 运行时,可以添加 适用于 ADOT Go 的 AWS 托管 Lambda 层以自动分析您的函数。有关如何添加此层的详细说明,请参阅 ADOT 文档中的 AWS Distro for OpenTelemetry Lambda 对 Go 的支持
使用 X-Ray SDK 分析您的 Go 函数
要记录有关 Lambda 函数对应用程序中的其他资源进行的调用的详细信息,您还可以使用适用于 Go 的 AWS X-Ray 开发工具包。要获取开发工具包,请使用 go get
从 GitHub 存储库
go get github.com/aws/aws-xray-sdk-go
要检测AWS开发工具包客户端,请将客户端传递给 xray.AWS()
方法。然后,您可以使用该方法的 WithContext
版本来跟踪调用。
svc := s3.New(session.New()) xray.AWS(svc.Client) ... svc.ListBucketsWithContext(ctx aws.Context, input *ListBucketsInput)
在添加正确的依赖项并进行必要的代码更改后,请通过 Lambda 控制台或 API 激活函数配置中的跟踪。
使用 Lambda 控制台激活跟踪
要使用控制台切换 Lambda 函数的活动跟踪,请按照以下步骤操作:
打开活跃跟踪
打开 Lamba 控制台的 Functions
(函数)页面。 -
选择函数。
选择 Configuration(配置),然后选择 Monitoring and operations tools(监控和操作工具)。
选择编辑。
-
在 X-Ray 下方,开启 Active tracing(活动跟踪)。
-
选择保存。
使用 Lambda API 激活跟踪
借助 AWS CLI 或 AWS SDK 在 Lambda 函数上配置跟踪,请使用以下 API 操作:
以下示例 AWS CLI 命令对名为 my-function 的函数启用活跃跟踪。
aws lambda update-function-configuration --function-name my-function \ --tracing-config Mode=Active
跟踪模式是发布函数版本时版本特定配置的一部分。您无法更改已发布版本上的跟踪模式。
使用 AWS CloudFormation 激活跟踪
要对 AWS CloudFormation 模板中的 AWS::Lambda::Function
资源激活跟踪,请使用 TracingConfig
属性。
例 function-inline.yml – 跟踪配置
Resources: function: Type: AWS::Lambda::Function Properties:
TracingConfig: Mode: Active
...
对于 AWS Serverless Application Model (AWS SAM) AWS::Serverless::Function
资源,请使用 Tracing
属性。
例 template.yml – 跟踪配置
Resources: function: Type: AWS::Serverless::Function Properties:
Tracing: Active
...
解释 X-Ray 跟踪
您的函数需要权限才能将跟踪数据上载到 X-Ray。在 Lambda 控制台中激活跟踪后,Lambda 会将所需权限添加到函数的执行角色。如果没有,请将 AWSXRayDaemonWriteAccess
在配置活跃跟踪后,您可以通过应用程序观察特定请求。X-Ray 服务图将显示有关应用程序及其所有组件的信息。以下示例显示了具有两个函数的应用程序。主函数处理事件,有时会返回错误。位于顶部的第二个函数将处理第一个函数的日志组中显示的错误,并使用 AWS SDK 调用 X-Ray、Amazon Simple Storage Service (Amazon S3) 和 Amazon CloudWatch Logs。
X-Ray 无法跟踪对应用程序的所有请求。X-Ray 将应用采样算法确保跟踪有效,同时仍会提供所有请求的一个代表性样本。采样率是每秒 1 个请求和 5% 的其他请求。您无法为函数配置此 X-Ray 采样率。
在 X-Ray 中,跟踪记录有关由一个或多个服务处理的请求的信息。Lambda 会每个跟踪记录 2 个分段,这些分段将在服务图上创建两个节点。下图突出显示了这两个节点:
位于左侧的第一个节点表示接收调用请求的 Lambda 服务。第二个节点表示特定的 Lambda 函数。以下示例显示了一个包含这 2 个分段的跟踪。两者都命名为 my-function,但其中一个函数具有 AWS::Lambda
源,另一个则具有 AWS::Lambda::Function
源。如果 AWS::Lambda
分段显示错误,则表示 Lambda 服务存在问题。如果 AWS::Lambda::Function
分段显示错误,则说明函数存在问题。
此示例将展开 AWS::Lambda::Function
分段,以显示其三个子分段。
注意
AWS 目前正在实施对 Lambda 服务的更改。由于这些更改,您可能会看到 AWS 账户 中不同 Lambda 函数发出的系统日志消息和跟踪分段的结构和内容之间存在细微差异。
此处显示的示例跟踪说明了旧样式函数分段。以下段落介绍了新旧样式分段之间的差异。
这些更改将在未来几周内实施,除中国和 GovCloud 区域外,所有 AWS 区域 的函数都将过渡到使用新格式的日志消息和跟踪分段。
旧样式函数分段包含以下子分段:
-
初始化 – 表示加载函数和运行初始化代码所花费的时间。此子分段仅对由您的函数的每个实例处理的第一个事件显示。
-
调用 – 表示执行处理程序代码花费的时间。
-
开销 – 表示 Lambda 运行时为准备处理下一个事件而花费的时间。
新样式函数分段不包含 Invocation
子分段。而是将客户子分段直接附加到函数分段。有关新旧样式函数分段结构的更多信息,请参阅 了解 X-Ray 跟踪。
您还可以分析 HTTP 客户端、记录 SQL 查询以及使用注释和元数据创建自定义子段。有关更多信息,请参阅《AWS X-Ray 开发人员指南》中的适用于 Go 的 AWS X-Ray 开发工具包。
定价
作为 AWS 免费套餐的组成部分,您可以每月免费使用 X-Ray 跟踪,但不能超过一定限制。超出该阈值后,X-Ray 会对跟踪存储和检索进行收费。有关更多信息,请参阅 AWS X-Ray 定价