AWS Lambda可以与S / FTP进行交互吗?

时间:2015-12-18 16:12:16

标签: node.js ftp sftp aws-lambda serverless-framework

我写了一些基本的js来列出FTP的文件,但我得到了:

“在完成请求之前退出流程”

是因为Lambda无法与FTP交互吗?

我正在使用jsftp btw。

这是我的设置:

  • 我使用Serverless创建项目
  • 对于我的lambda,我使用了nodejs,我使用JSFTP来处理ftp的东西。

我的代码:

// Require Serverless ENV vars
var ServerlessHelpers = require('serverless-helpers-js').loadEnv();

// Require Logic
var lib = require('../lib');

// Lambda Handler
module.exports.handler = function (event, context) {

    lib.respond(event, function (error, response) {
        return context.done(error, response);
    });
};

我的ftp lambda代码:

var JSFtp = require("jsftp");

module.exports.respond = function (event, cb) {

    var ftp = new JSFtp({
        host: "host",
        user: "user",
        password: "password"
    });

    ftp.auth(ftp.user, ftp.password, function(err, res) {
        if (err) console.log(err);
        else console.log(res);

        ftp.ls(".", function (err, res) {
            var results = [];
            res.forEach(function (file) {
                results.push(file.name);
            });

            ftp.raw.quit();

            return cb(null, results.length);
        })
    });
};

我在整个地方添加了一些console.log(),一旦尝试ftp.auth,它似​​乎就会被阻塞。

我在云观察中看到的输出:

START RequestId: __ID__ Version: $LATEST
END RequestId: __ID__
REPORT RequestId: __ID__    Duration: 526.46 ms Billed Duration: 600 ms     Memory Size: 1024 MB    Max Memory Used: 33 MB  
Process exited before completing request

所以看起来它只是在某处窒息......

3 个答案:

答案 0 :(得分:4)

简而言之,ftp不适用于lambda,因为它们使用临时端口。

sftp将与lambda很好地协作。我通过jsch使用java代码测试没有问题;我无法看到它如何与任何js sftp lib一起使用。

答案 1 :(得分:3)

刚才可以进行测试。 确保将ur timeout设置为足够长,并且在进程终止时调用context.succeed()

function __main__(event, context) {
    var JSFtp = require("jsftp");
    var ftp = new JSFtp({
        host: "speedtest.tele2.net",
        port: 21, // defaults to 21
    });
    ftp.ls(".", function(err, res) {
      var results = []; res.forEach(function(file) {
        results.push(file.name);
      });
      context.succeed(results);
    });
};

答案 2 :(得分:1)

默认情况下,Lambda函数只需3秒即可完成。如果花费的时间比这要长,你就会得到你所看到的错误。

您可以将超时调整为最多5分钟。要使用aws lambda update-function-configuration --function-name my-lambda-function --timeout 300 CLI更改它,请运行:

{{1}}