如何使动态dynamodb X射线查询作为自定义细分的细分?

问题描述

我有一个lambda函数,可以多次查询dynamodb。我想使用xray来获得有关查询性能

我在nodejs中创建了lambda:

this.documentClient = new DocumentClient({
      service: new DynamoDB(),});
AWSXray.captureAWSClient((this.documentClient as any).service);

查询dynamodb时,我正在使用代码

const segment = AWSXRay.getSegment();
const subsegment = segment.addNewSubsegment('query dynamodb');
await this.documentClient.query(...).promise();
await this.documentClient.query(...).promise();
await this.documentClient.query(...).promise();
...
subsegment.close();

我能够看到跟踪数据:

enter image description here

但是问题是query dynamodb段不是其他动态发电机查询子段的父段。如何将所有dynamodb查询包装在自定义细分中?

解决方法

我认为这里的问题是query dynamodb子段未在要为父项的DynamoDB子段的上下文中设置。因此,所有子段的父级都是Lambda FacadeSegment。您可以尝试使用Manual Mode手动将subsegment传递给DDB调用。有关详细信息,请参见example

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...