AWS Cognito lambda触发两次
我正在使用AWS Lambda函数(使用nodejs)。
从APP到Cognito的任何请求都要签署用户。然后我设置了预注册触发器来验证用户的客户并检查我们数据库中是否有可用的用户自定义属性。如果是,则返回错误,否则在DB中插入新记录并将事件返回到Cognito。
TimeoutInfo - 5分钟。
它发生在请求中的某个时间,而不是所有时间。 RequestId不同。 (它会在某个时间触发3次,大部分时间会触发两次)
Lambda触发器代码如下。
用户/ index.js
const handler = async (event, context) => {
log.info('createUserLambda:start');
// immediately return once the call back is called to avoid
// lambda time out because of any open db connections
context.callbackWaitsForEmptyEventLoop = false;
return await preUserCreate(event);
};
exports.handler = handler;用户/ users.js
export const preUserCreate = async (event) => {
log.info('preUserCreate:Start');
let userAttributes = event.request.userAttributes;
const currentDate = moment().utc().format('YYYY-MM-DD HH:mm:ss');
try {
let userParams = {
'docStatus': 'VRF'
};
let docParams = [{
'docNumber': userAttributes['custom:document_number'] ? userAttributes['custom:document_number'] : '',
'createdDate': currentDate
}];
if (docParams.length && docParams[0].docNumber) {
let documentExit = await getDocs(docParams[0].docNumber);
if (documentExit.length) {
log.info('preUserCreate:Error');
throw new Error('Document number already exist.');;
}
}
let documentRs = await insertDocument(docParams);
userParams = {
'did': documentRs[0].id,
'id': event.userName,
'createdDate': currentDate,
'updatedDate': currentDate,
...userParams
};
let userRs = await insertUser([userParams]);
if (docParams.length && docParams[0].docNumber) {
let resultData = await getUserAccountFromAPI(docParams[0].docNumber);
if (resultData) {
let foramattedData = await formattedAccountsData(resultData, userRs[0].id, documentRs[0].id);
await insertUserAccounts(foramattedData);
}
}
log.info('preUserCreate:Success');
event.response = {
'autoConfirmUser': false,
'autoVerifyPhone': false,
'autoVerifyEmail': false
};
return event;
} catch (error) {
log.info('preUserCreate:Error', error);
throw (error);
}
}
回答如下:
这可能是因为Cognito强加的执行超时为5秒,因此集成Lambdas - 并且无法更改。另请注意,Cognito将(重新)尝试调用该函数的最大次数是3次。
在Customizing User Pool Workflows with Lambda Triggers部分,它指出:
重要Amazon Cognito同步调用Lambda函数。调用时,您的Lambda函数必须在5秒内响应。如果没有,Amazon Cognito将重试该呼叫。在3次尝试失败后,该功能超时。此5秒超时值无法更改。
因此,为了减少执行时间,值得考虑在可能的情况下引入缓存。包括数据库连接等
但请注意,您几乎无法控制Lambdas重新使用的频率与重新启动的比例,您需要在预热时间内牢记这一点。