我写了一些基本的 js 来列出 FTP 的文件,但我得到了:
“完成请求前进程退出”
那是因为 Lambda 无法与 FTP 交互吗?
我正在使用 jsftp 顺便说一句。
这是我的设置:
- 我使用无服务器来创建项目
- 对于我的 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
所以看起来它只是在某个地方窒息......