FTPのファイルをリストするだけの基本的なjsをいくつか書きましたが、次のようになります。
「リクエストを完了する前にプロセスが終了しました」
これは、Lambda が FTP と対話できないためですか?
私はところでjsftpを使用しています。
これが私のセットアップです:
- サーバーレスを使用してプロジェクトを作成します
- 私のラムダでは、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ラムダコード:
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
それで、どこかで窒息したように見えます...