无服务器502错误网关

时间:2019-01-12 21:33:09

标签: node.js amazon-web-services aws-lambda serverless

我能够按照文档创建一个简单的无服务器功能,但是当我添加http侦听器时,在尝试触碰端点时会不断收到502 Bad Gateway

我该如何调试呢?

'use strict';

module.exports.hello = async (event, context) => {
  return {
    statusCode: 200,
    body: {
      message: 'Go Serverless v1.0! Your function executed successfully!',
      input: event,
    },
  };
};

serverless.yaml

service: playing-with-serverless # NOTE: update this with your service name

provider:
  name: aws
  runtime: nodejs8.10

functions:
  hello:
    handler: handler.hello
    events:
      - http:
          path: hello
          method: get

我已经部署了功能

 $ sls deploy
Serverless: Packaging service...
Serverless: Excluding development dependencies...
Serverless: Uploading CloudFormation file to S3...
Serverless: Uploading artifacts...
Serverless: Uploading service .zip file to S3 (423 B)...
Serverless: Validating template...
Serverless: Updating Stack...
Serverless: Checking Stack update progress...
..............
Serverless: Stack update finished...
Service Information
service: playing-with-serverless
stage: dev
region: us-east-1
stack: playing-with-serverless-dev
api keys:
  None
endpoints:
  GET - https://1r5mt9wa63.execute-api.us-east-1.amazonaws.com/dev/hello
functions:
  hello: playing-with-serverless-dev-hello
layers:
  None
Serverless: Removing old service artifacts from S3...

cURL

$ curl --request GET \
  --url https://1r5mt9wa63.execute-api.us-east-1.amazonaws.com/dev/hello
{"message": "Internal server error"}%```  

2 个答案:

答案 0 :(得分:3)

您需要在响应对象中将body字符串化:

return {
  statusCode: 200,
  body: JSON.stringify({
    message: 'Go Serverless v1.0! Your function executed successfully!',
    input: event
  })
};

See docs特别是Output Format of a Lambda Function for Proxy Integration

Set up an Integration Response in API Gateway

答案 1 :(得分:0)

您的服务器端代码可能存在错误。

尝试在 AWS 控制台上测试您的请求。如果有错误,它会准确地指出您的 Javascript 代码中的错误。

enter image description here