2

我有一个 node.js 函数,我想将它部署为 AWS Lambda 函数。我注意到当我使用 redis Elasticache 时,我必须关闭我用 redis.createClient 打开的连接,否则 Lambda 函数会超时。我通过简单地调用客户端的 quit() 方法来做到这一点。如果我在发出 Lambda 回调之前执行此操作,则 Lambda 函数会按预期结束。如果我不这样做,则 Lambda 函数会在我设置的任何超时间隔处超时。在测试设置中,我有一个 Lambda 函数,它在缓存上运行并在 30 毫秒内终止。如果不调用 redis 客户端 quit() 方法,相同的 Lambda 函数不会在 1 分钟超时之前终止。我不确定,但我认为 Lambda 函数的行为方式是这样的,因为它没有

我并不关心这个,因为调用 quit() 方法很容易。我遇到的问题是当我尝试使用 DynamoDB DAX 客户端做类似的事情时。我可以让 Lambda 函数通过我的 VPC 终端节点直接访问 DynamoDB,一切正常。如果我使用 DAX 客户端,对表的修改实际上会发生(我插入了一个项目,可以看到它在那里),但 Lambda 函数总是超时。

这是一些示例代码:

const AmazonDaxClient = require('amazon-dax-client');
const AWS             = require('aws-sdk');
const config          = require('./config');

AWS.config.update(config.aws);
var ddbClient = new AWS.DynamoDB.DocumentClient(config.dynamodb);
var dax = new AmazonDaxClient(config.dax);
var daxClient = new AWS.DynamoDB.DocumentClient({service: dax });

如果我只使用 ddbClient,一切正常。如果我使用 daxClient,一切正常(插入、删除、更新等),但 Lambda 函数超时。daxClient 是否有类似的 quit() 方法告诉 DAX 集群我已完成并且可以干净地关闭所有连接?我怀疑这个问题是他们希望 daxClient 的行为与普通 ddbClient 完全一样,并且 ddbClient 没有 quit() 方法。

4

2 回答 2

3

看起来像此处记录的 Lambdacontext属性可能与您的案例相关。默认情况下它设置为,这意味着即使您的处理程序通过回调返回一个值,只要 Node 事件循环中仍有任何内容,Lambda 将不会完成其执行。callbackWaitsForEmptyEventLooptrue

将其设置为false将允许您的 Lambda 处理程序即使在事件循环中完成,但请注意这些逻辑线程将在 Lambda 未运行时冻结执行。此行为可能不适用于所有库,具体取决于它们的健壮程度。

有趣的是,无论属性的设置如何,旧的 Lambda 返回风格的调用context.succeed(而不是callback)都不会等待一个空的事件循环。(这个要点涉及一些额外的细节。)

于 2017-11-21T22:10:59.917 回答
1

从 DAX JS 客户端的 1.1.2 版开始,这不再是问题 - 使用 DAX 时 Lambda 事件循环将正确暂停。

于 2018-06-13T22:20:51.227 回答