【发布时间】:2019-01-14 02:05:32
【问题描述】:
我也是无服务器和 AWS 的新手。所以我的要求是这样的。我需要从 S3 下载文件。我已经尝试了很多方法。我阅读了很多文章,但找不到适合此目的的文档。
所以我所做的是,我使用 Serverless 创建了一个样板,并获取了所有文件,例如 handler.js、serverless.yml
我需要知道从 S3 下载文件的正确步骤。
我尝试的是。 Handler.js
const AWS = require('aws-sdk');
const S3= new AWS.S3();
exports.hello = async (event, context) => {
console.log(`Hi from Node.js ${process.version} on Lambda!`)
S3.getObject({Bucket: '*******', Key: '******'}).promise().then( data =>{
return {
statusCode: 200,
body: data
})
}
Serveless.yml
service: node11
custom:
bucket: *********
provider:
name: aws
runtime: provided # set to provided
stage: dev
region: us-east-1
iamRoleStatements:
- Effect: Allow
Action:
- s3:*
Resource: "arn:aws:s3:::${self:custom.bucket}/*"
functions:
hello:
handler: handler.hello
events:
- http:
path: /
method: get
layers: # add layer
- arn:aws:lambda:us-east-1:553035198032:layer:nodejs11:3
无论我做什么,我总是收到类似 INTERNAL SERVER ERROR 的错误。
从 S3 获取文件的正确方法是什么?
【问题讨论】:
-
向您的 Lambda 函数添加额外的 console.log() 语句,尤其是在 getObject() 调用的成功/失败分支中,然后查看 CloudWatch Logs 中的日志以了解发生了什么。跨度>
标签: amazon-web-services amazon-s3 serverless-framework serverless aws-serverless