我写了一些基本的js来列出FTP的文件,但我得到了:
“在完成请求之前退出流程”
是因为Lambda无法与FTP交互吗?
我正在使用jsftp btw。
这是我的设置:
我的代码:
// 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
所以看起来它只是在某处窒息......
答案 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}}