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

I can't read from the environment variable (aws-lambda in Go)

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

我运行"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

已解决。

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

第二个问题:"Function 'UserGetFunction' timed out after 5 seconds"
出错 这是因为 "localhost" 表达式。将 env.json 中的 "localhost" 重写为 "xxx.xxx.xxx.xxx" 工作正常。("xxx.xxx.xxx.xxx" 是您笔记本电脑的 ip 地址)