Node.js 成功完成后AWS Lambda功能超时

Node.js 成功完成后AWS Lambda功能超时,node.js,amazon-web-services,aws-lambda,Node.js,Amazon Web Services,Aws Lambda,我有一个lambda函数,它可以成功地工作。我能够在S3和另一个FTP服务器上创建一个文件。问题甚至在成功完成后也会超时。它只是没有完成执行。我可以从日志中看到,它大约需要2秒,指定的超时时间是5秒。如何使函数在完成后立即停止?以下是完整的代码: "use strict"; var config = require('./config/dev'); var sql = require("mssql"); var AWS = require('aws-sdk'); var PromiseFtp

我有一个lambda函数,它可以成功地工作。我能够在S3和另一个FTP服务器上创建一个文件。问题甚至在成功完成后也会超时。它只是没有完成执行。我可以从日志中看到,它大约需要2秒,指定的超时时间是5秒。如何使函数在完成后立即停止?以下是完整的代码:

"use strict";

var config = require('./config/dev');
var sql = require("mssql");
var AWS = require('aws-sdk');
var PromiseFtp = require('promise-ftp');
var fs = require('fs');
const request = require('request');


exports.handler = (event, context, callback) => {
    GetDataFromServer(event, context, callback);
};

function GetDataFromServer(event, context, callback) {
    console.log("Fetching data from database...");
    var keys = [], outputText = '';
    sql.connect(config.db, err => {
        if (err) {
            console.log("Error while connecting database :- " + err);
            return callback(true, 'Error in fetching records from database...');
        }
        else {
            new sql.Request()
                .input('ClientId', sql.Int, 469)
                .execute('ForesightDailyDataPull', (err, result) => {
                    if (!err) {
                        //Create Text here and assign to "outputText"
                        CreateFileOnS3(outputText, event, context, callback);
                    }
                    else {
                        console.log('Error in fetching records from database...');
                        return callback(true, 'Error in fetching records from database...');
                    }
                })
        }
    });
    sql.on('error', err => {
        console.log('Error in fetching records from database...');
        return callback(true, 'Error in fetching records from database...');
    })
}

function CreateFileOnS3(fileData, event, context, callback) {
    const fileName = generateFileName();
    console.log('Sending file to S3...');
    const s3 = new AWS.S3(config.awsCredentials);
    const params = {
        Bucket: config.app.s3Bucket,
        Key: fileName,
        Body: fileData
    };
    s3.upload(params, function (s3Err, data) {
        if (s3Err) {
            console.log('There was an error creating file on S3');
            return callback(true, 'There was an error creating file on S3');
        }
        else {
            console.log(`File uploaded successfully at ${data.Location}`);
            CreatefileOnFTP(fileData, fileName, event, context, callback);
        }
    });
}

function CreatefileOnFTP(fileData, fileName, event, context, callback) {
    console.log('Sending file to FTP...');
    var ftpObject = {
        "fileData": fileData,
        "fileName": fileName,
        "ftpURL": config.ftpDetails.ftpProtocol + "://" + config.ftpDetails.host,
        "ftpUserName": config.ftpDetails.user,
        "ftpPassword": config.ftpDetails.password
    };
    request({
        url: config.ftpUploadURL,
        method: "POST",
        json: true,
        body: ftpObject
    }, function (error, response, body) {
        if (!error) {
            console.log('File sent successfully to FTP server.');
            return callback(null, 'File sent successfully to FTP...');
        }
        else {
            console.log('An error occurred while sending file to FTP.');
            return callback(true, 'Error in sending file to FTP...');
        }
    });
}

function generateFileName() {
    var _d = new Date(),
        y = _d.getFullYear(),
        m = _d.getMonth() + 1,
        d = _d.getDate();
    return y + '-' + (m < 10 ? '0' + m : m) + '-' + (d < 10 ? '0' + d : d) + '.txt';
}

您应该在函数完成后通过在操作解析后调用sql.close来关闭打开的sql连接

function GetDataFromServer(event, context, callback) {
    console.log("Fetching data from database...");
    var keys = [], outputText = '';
    sql.connect(config.db, err => {
        if (err) {
            console.log("Error while connecting database :- " + err);
            return callback(true, 'Error in fetching records from database...');
        }
        else {
            new sql.Request()
                .input('ClientId', sql.Int, 469)
                .execute('ForesightDailyDataPull', (err, result) => {
                    if (!err) {
                        //Create Text here and assign to "outputText"
                        CreateFileOnS3(outputText, event, context, callback);
                        sql.close() //HERE
                    }
                    else {
                        console.log('Error in fetching records from database...');
                        sql.close() //HERE
                        return callback(true, 'Error in fetching records from database...');

                    }
                })
        }
    });
    sql.on('error', err => {
        console.log('Error in fetching records from database...');
        sql.close() //HERE
        return callback(true, 'Error in fetching records from database...');
    })
}

AWS Lambda继续Lambda函数调用,直到事件循环为空。您的良好路径似乎调用了提供的回调,第一个参数为null,因此您的事件循环可能不是空的?@jarmod我不知道如何将事件循环设为空。有没有办法停止执行该函数。我不是100%确定这是原因,但这是一个重要的声明,说明Lambda服务如何知道Lambda函数是完整的,不仅仅是函数返回或回调。如果将超时时间从5秒增加到30秒,是否在2秒时完成处理,然后在30秒时超时?我想知道你的MySQL和/或FTP客户端对象是否是原因?你能试着关闭/拆开它们进行测试吗?我假设您肯定看到日志文件成功发送到FTP。。。在Lambda超时之前的某个时间。