AWS X Ray节点js跟踪未显示

时间:2019-03-27 04:35:56

标签: node.js amazon-web-services aws-lambda aws-xray

我正在使用Lambda(节点8.10)并使用AWS X Ray。我正在使用promise呼叫外部IP地址。 当我打电话时,会显示其他迹线,但无法获得自定义段。 我不使用任何框架,而不仅仅是纯节点js。

const AWSXRay = require('aws-xray-sdk-core');

AWSXRay.enableManualMode();
AWSXRay.captureHTTPsGlobal(require('https'));

const https = AWSXRay.captureHTTPs(require('https'));

exports.handler = async (event, context, callback) => {
// other code

const response = await doSomething(event);
    return callback(error, response);
};

async doSomething(event) {
return new Promise((resolve, reject) => {
    const segment = new AWSXRay.Segment('custom_segment_here');

    AWSXRay.captureAsyncFunc('send', (subsegment) => {
        const options = {
                    hostname: host,
                    port: 443,
                    path: '/',
                    method: 'GET',
                    XRaySegment: subsegment,
                };

        const req = https.request(options, (res) => {
            code = res.statusCode;
            resolve(code);
        });

        req.on('error', (error) => {
                    subsegment.addError(error);
                    reject(error);
                });

                subsegment.close();
                req.end();
    }, segment);

}

}

1 个答案:

答案 0 :(得分:0)

在Lambda场景中,Lambda负责创建细分,AWS X-Ray SDK仅创建子细分,然后发出它们。根据您的代码段,您在lambda函数中创建了一个无法发射的段(const segment = new AWSXRay.Segment('custom_segment_here');),因此您无法在控制台中看到它。希望我的答案是明确的。 :)