- About 10% of request have 403 forbidden status code return from s3 backend
- nginx are not able to follow 60s ttl announced by s3 dns record.(nginx community version dos not support dynamic dns resolve feature)
- nginx+lua are not able to handle 100-continue return code from s3 backend
- nginx+lua sometime generating unnecessary disk io
- s3 gateway performance is bound to s3 api request limit and not nginx qps limit
- Inhouse s3 gateway is not able to use IAM role to eliminate the risk of key loss
- Inhouse s3 gateway is subject to aws signing method changes in the future.
So we planed to refactor this service using native aws SDK, two candidates are selected, boto3 and aws golang sdk. We pick up aws-golang-sdk at the end because:
- boto3 did not support python 2.6 in centos 6 environment
- adding additional http server framework on top of boto3 make the deployment process more complex
- golang have better memory footprint than python
Below are some code snippets:
- Use static credential for instance outside ec2 or existing ec2 instance without IAM role
var conf *aws.Config
conf = &aws.Config{
Region: aws.String(REGION),
Credentials: credentials.NewStaticCredentials("", "",""),
}
- Use IAM role credential
Region: aws.String(REGION),
Credentials: credentials.NewCredentials(&ec2rolecreds.EC2RoleProvider{Client: ec2metadata.New(session.New())}),
}
OR (aws sdk including aws-cli use instance IAM role by default)
conf = &aws.Config{
Region: aws.String(REGION),
}
- Get HTTP return code from s3 backend
func get_http_status_code_from_error(err error) (int,string) {
if awsErr, ok := err.(awserr.RequestFailure); ok {
return awsErr.StatusCode(),awsErr.Code()
} else {
return 500,err.Error()
}
}
没有评论:
发表评论