AWS Lambda 和 AWS X-Ray - AWS X-Ray
AWS 文档中描述的 AWS 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 AWS 服务入门

AWS Lambda 和 AWS X-Ray

您可以使用 AWS X-Ray 跟踪 AWS Lambda 函数。Lambda 运行 X-Ray 守护程序并记录分段以及有关函数调用和执行的详细信息。如需进一步分析,您可以将 X-Ray 开发工具包与您的函数绑定,以便记录传出调用以及添加注释和元数据。

如果您的 Lambda 函数由另一个已分析服务调用,则 Lambda 将不使用任何附加配置来跟踪已采样的请求。上游服务可以是经过分析的 Web 应用程序或另一个 Lambda 函数。您的服务可以直接使用已检测的 AWS SDK 客户端调用该函数,或者通过使用已检测的 HTTP 客户端调用 API 网关 API 来调用该函数。

如果您的 Lambda 函数按计划运行,或者由未检测的服务调用,您可以将 Lambda 配置为通过活动跟踪采样和记录调用。

在 AWS Lambda 函数上配置 X-Ray 集成

  1. 打开 AWS Lambda 控制台

  2. 选择您的函数。

  3. 选择 Configuration

  4. AWS X-Ray 下,启用 Active tracing (活动跟踪)

在运行时,通过对应的 X-Ray 开发工具包,Lambda 也运行 X-Ray 守护程序。

Lambda 上的 X-Ray 开发工具包

  • X-Ray SDK for Go – Go 1.7 和更新版本的运行时

  • X-Ray SDK for Java – Java 8 运行时

  • X-Ray SDK for Node.js – Node.js 4.3 和更新版本的运行时

  • X-Ray SDK for Python – Python 2.7、Python 3.6 和更新版本的运行时

  • X-Ray SDK for .NET – .NET Core 2.0 和更新版本的运行时

要在 Lambda 上使用 X-Ray 开发工具包,请在每次创建新版本时将其与您的函数代码绑定。您可以用分析运行在其他服务上的应用程序的相同方法来分析您的 Lambda 函数。主要差别在于您不使用开发工具包来分析传入请求、做出采样决策和创建分段。

检测 Lambda 函数和 Web 应用程序的另一个差别在于,Lambda 创建并发送到 X-Ray 的分段无法通过函数代码进行修改。您可以创建子分段并在其上记录注释和元数据,但无法将批注和元数据添加到父分段。

有关更多信息,请参阅 AWS Lambda 开发人员指南 中的使用 AWS X-Ray