我无法读取环境变量(Go中的aws-lambda)

时间:2019-09-15 09:12:48

标签: amazon-web-services go aws-lambda aws-api-gateway dynamo-local

我想使用DynamoDB Local和SAM CLI在本地环境中测试AWS Lambda。 我创建了一个简单的用户数据库表(ID,名称),并试图获取数据。

我运行“ sam local start-api --env-vars test / env.json”。当我访问“ http://localhost:3000/users/1”时,发生了错误。错误消息如下。我无法理解此错误消息的含义。如何解决此错误?

{
  "errorMessage": "InvalidParameter: 1 validation error(s) found.\n- minimum field size of 3, GetItemInput.TableName.\n",
  "errorType": "ErrInvalidParams"
}

这是我的代码。

func handler(request events.APIGatewayProxyRequest) (events.APIGatewayProxyResponse, error) {
    // Environment variables
    endpoint := os.Getenv("DYNAMODB_ENDPOINT")
    tableName := os.Getenv("DYNAMODB_TABLE_NAME")

    // Request
    id, _ := request.PathParameters["id"]

    // DynamoDB
    sess := session.Must(session.NewSession())
    config := aws.NewConfig().WithRegion("ap-northeast-1")
    if len(endpoint) > 0 {
        config = config.WithEndpoint(endpoint)
    }

    db := dynamodb.New(sess, config)
    response, err := db.GetItem(&dynamodb.GetItemInput{
        TableName: aws.String(tableName),
        Key: map[string]*dynamodb.AttributeValue{
            "Id": {
                N: aws.String(string(id)),
            },
        },
        AttributesToGet: []*string{
            aws.String("Id"),
            aws.String("Name"),
        },
        ConsistentRead:         aws.Bool(true),
        ReturnConsumedCapacity: aws.String("NONE"),
    })
    if err != nil {
        return events.APIGatewayProxyResponse{}, err
    }

    user := User{}
    err = dynamodbattribute.Unmarshal(&dynamodb.AttributeValue{M: response.Item}, &user)
    if err != nil {
        return events.APIGatewayProxyResponse{}, err
    }

    // Json
    bytes, err := json.Marshal(user)
    if err != nil {
        return events.APIGatewayProxyResponse{}, err
    }

    return events.APIGatewayProxyResponse{
        Body:       string(bytes),
        StatusCode: 200,
    }, nil
}

error message

1 个答案:

答案 0 :(得分:0)

已解决。

第一个问题:无法从环境变量中读取
这是因为template.yaml的缩进大小偏差。类别“ 事件”和类别“ 环境”必须一致。

第二个问题:“功能'UserGetFunction'在5秒后超时”的错误
这是因为“ localhost”表达式。将env.json中的“ localhost”重写为“ xxx.xxx.xxx.xxx”工作正常。(“ xxx.xxx.xxx.xxx”是您笔记本电脑的IP地址)