我无法读取环境变量(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 地址)
我想使用 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 地址)