我有这样的NodeJS 12.x Lambda,我正在使用middy.js连接到一个RedShift集群,下面是一个摘录:
const middy = require('@middy/core')
const dbManager = require('@middy/db-manager');
const lambda = middy(async (event, context) => {
const { db } = context;
const records = await db.distinct('XXX').from('YYY');
// print result
console.log(records);
// return result
return {
'statusCode': 200,
'body': JSON.stringify(records)
}
});
lambda
.use(dbManager({
config: {
client: 'pg',
connection: {
host: 'XXX',
port: '1111',
schema: 'public',
user: 'XXX',
password: 'XXX',
database: 'XXX'
}
}
}));
module.exports = { lambda }当我运行这个Lambda时,检索到了结果(即console.log输出了结果),但是该函数一直保持挂起状态,直到它没有到达超时时间。我很确定我在异步/等待机制中遗漏了一些东西,但我不知道我必须在哪里改变什么。
发布于 2020-04-29 00:00:40
解决方案是设置context.callbackWaitsForEmptyEventLoop = false。
这可以通过使用名为DoNotWaitForEmptyEventLoop的中间件来完成
https://stackoverflow.com/questions/61484051
复制相似问题