如何在 Lambda 中将对象上传到 S3


似乎

无法将对象上传到 Lambda 中的 S3 中。当地一切正常。日志中没有显示错误,可以显示出了什么问题...

代码如下:

console.log('Loading function');
var AWS = require('aws-sdk');
var s3 = new AWS.S3();
exports.handler = function(event, context) {
    //console.log(JSON.stringify(event, null, 2));
    var s3 = new AWS.S3();
    var param = {Bucket: 'flow-logs', Key: 'test-lambda-x', Body: 'me me me'};
    console.log("s3");
    s3.upload(param, function(err, data) {
        if (err) console.log(err, err.stack); // an error occurred
        else console.log(data);           // successful response
    });
    console.log('done');
    context.done();
};

成功运行,没有错误,但似乎没有调用 s3.upload 中的回调。不会在存储桶中创建任何对象。

通过授予完全访问权限以及在本地测试,验证 IAM 角色权限不是问题。

输出

START RequestId: d4847fdb-160c-11e5-8a8c-b555b123e14d
2015-06-18T22:53:29.750Z    d4847fdb-160c-11e5-8a8c-b555b123e14d    s3
2015-06-18T22:53:30.271Z    d4847fdb-160c-11e5-8a8c-b555b123e14d    done
END RequestId: d4847fdb-160c-11e5-8a8c-b555b123e14d

我怀疑你在s3.upload()有机会返回之前调用了context.done()函数。 如果将context.done()移动到上传响应代码块中,它应该可以正常工作。

var AWS = require('aws-sdk');
var s3 = new AWS.S3();
exports.handler = function(event, context) {
    //console.log(JSON.stringify(event, null, 2));
    var s3 = new AWS.S3();
    var param = {Bucket: 'flow-logs', Key: 'test-lambda-x', Body: 'me me me'};
    console.log("s3");
    s3.upload(param, function(err, data) {
        if (err) console.log(err, err.stack); // an error occurred
        else console.log(data);           // successful response
        console.log('actually done!');
        context.done();
    });
    console.log('done?');
    //context.done();
};

最新更新