Browse Source

perf(fix): fix bugs

Signed-off-by: changlin.shi <changlin.shi@ly.com>
pull/5936/head
changlin.shi 2 years ago
parent
commit
fa8698f6c3
  1. 2
      weed/s3api/bucket_metadata.go
  2. 9
      weed/s3api/s3api_acp.go
  3. 3
      weed/s3api/s3api_bucket_handlers.go
  4. 8
      weed/s3api/s3api_object_copy_handlers.go
  5. 2
      weed/s3api/s3api_server.go
  6. 2
      weed/server/filer_server_handlers_write_autochunk.go
  7. 1
      weed/util/http_util.go

2
weed/s3api/bucket_metadata.go

@ -190,7 +190,7 @@ func (r *BucketRegistry) LoadBucketMetadataFromFiler(bucketName string) (*Bucket
if err != nil { if err != nil {
if err == filer_pb.ErrNotFound { if err == filer_pb.ErrNotFound {
// The bucket doesn't actually exist and should no longer loaded from the filer // The bucket doesn't actually exist and should no longer loaded from the filer
glog.Warning("bucket not found in filer: ", bucketName)
glog.V(4).Info("bucket not found in filer: ", bucketName)
r.notFound[bucketName] = struct{}{} r.notFound[bucketName] = struct{}{}
return nil, s3err.ErrNoSuchBucket return nil, s3err.ErrNoSuchBucket
} }

9
weed/s3api/s3api_acp.go

@ -370,14 +370,9 @@ func (s3a *S3ApiServer) checkAccessForWriteObject(r *http.Request, bucket, objec
} }
objectOwnerId := s3acl.GetAcpOwner(entry.Extended, *bucketMetadata.Owner.ID) objectOwnerId := s3acl.GetAcpOwner(entry.Extended, *bucketMetadata.Owner.ID)
//object owner is immutable
if requestOwnerId != "" && objectOwnerId != requestOwnerId {
return s3err.ErrAccessDenied
}
//Only the owner of the bucket and the owner of the object can overwrite the object
if s3acl.ValidateAccount(requestOwnerId, objectOwnerId, *bucketMetadata.Owner.ID) {
glog.V(3).Infof("checkAccessForWriteObject denied! request account id: %s, expect account id: %s", requestAccountId, *bucketMetadata.Owner.ID)
//object owner is immutable
if !s3acl.ValidateAccount(requestOwnerId, objectOwnerId, *bucketMetadata.Owner.ID) {
return s3err.ErrAccessDenied return s3err.ErrAccessDenied
} }

3
weed/s3api/s3api_bucket_handlers.go

@ -6,9 +6,9 @@ import (
"errors" "errors"
"fmt" "fmt"
"github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil" "github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil"
"github.com/seaweedfs/seaweedfs/weed/s3api/s3bucket"
"github.com/seaweedfs/seaweedfs/weed/s3api/s3account" "github.com/seaweedfs/seaweedfs/weed/s3api/s3account"
"github.com/seaweedfs/seaweedfs/weed/s3api/s3acl" "github.com/seaweedfs/seaweedfs/weed/s3api/s3acl"
"github.com/seaweedfs/seaweedfs/weed/s3api/s3bucket"
"github.com/seaweedfs/seaweedfs/weed/util" "github.com/seaweedfs/seaweedfs/weed/util"
"math" "math"
"net/http" "net/http"
@ -146,6 +146,7 @@ func (s3a *S3ApiServer) PutBucketHandler(w http.ResponseWriter, r *http.Request)
entry.Extended = make(map[string][]byte) entry.Extended = make(map[string][]byte)
} }
entry.Extended[s3_constants.AmzIdentityId] = []byte(identityId) entry.Extended[s3_constants.AmzIdentityId] = []byte(identityId)
s3a.bucketRegistry.LoadBucketMetadata(entry)
} }
if objectOwnership != "" { if objectOwnership != "" {
if entry.Extended == nil { if entry.Extended == nil {

8
weed/s3api/s3api_object_copy_handlers.go

@ -98,8 +98,7 @@ func (s3a *S3ApiServer) CopyObjectHandler(w http.ResponseWriter, r *http.Request
return return
} }
glog.V(2).Infof("copy from %s to %s", srcUrl, dstUrl) glog.V(2).Infof("copy from %s to %s", srcUrl, dstUrl)
destination := fmt.Sprintf("%s/%s%s", s3a.option.BucketsPath, dstBucket, dstObject)
etag, errCode := s3a.putToFiler(r, dstUrl, resp.Body, destination)
etag, errCode := s3a.putToFiler(r, dstUrl, resp.Body, "")
if errCode != s3err.ErrNone { if errCode != s3err.ErrNone {
s3err.WriteErrorResponse(w, r, errCode) s3err.WriteErrorResponse(w, r, errCode)
@ -213,6 +212,11 @@ func processMetadata(reqHeader, existing http.Header, replaceMeta, replaceTaggin
} }
} }
// content-encoding
if contentEncoding, ok := existing["Content-Encoding"]; ok {
reqHeader["Content-Encoding"] = contentEncoding
}
if !replaceMeta { if !replaceMeta {
for header, _ := range reqHeader { for header, _ := range reqHeader {
if strings.HasPrefix(header, s3_constants.AmzUserMetaPrefix) { if strings.HasPrefix(header, s3_constants.AmzUserMetaPrefix) {

2
weed/s3api/s3api_server.go

@ -68,6 +68,7 @@ func NewS3ApiServer(router *mux.Router, option *S3ApiServerOption) (s3ApiServer
s3ApiServer.client = &http.Client{Transport: &http.Transport{ s3ApiServer.client = &http.Client{Transport: &http.Transport{
MaxIdleConns: 1024, MaxIdleConns: 1024,
MaxIdleConnsPerHost: 1024, MaxIdleConnsPerHost: 1024,
DisableCompression: true,
}} }}
} else { } else {
s3ApiServer.client = &http.Client{ s3ApiServer.client = &http.Client{
@ -75,6 +76,7 @@ func NewS3ApiServer(router *mux.Router, option *S3ApiServerOption) (s3ApiServer
DialContext: func(_ context.Context, _, _ string) (net.Conn, error) { DialContext: func(_ context.Context, _, _ string) (net.Conn, error) {
return net.Dial("unix", option.LocalFilerSocket) return net.Dial("unix", option.LocalFilerSocket)
}, },
DisableCompression: true,
}, },
} }
} }

2
weed/server/filer_server_handlers_write_autochunk.go

@ -237,7 +237,7 @@ func (fs *FilerServer) saveMetaData(ctx context.Context, r *http.Request, fileNa
for k, v := range r.Header { for k, v := range r.Header {
if len(v) > 0 && len(v[0]) > 0 { if len(v) > 0 && len(v[0]) > 0 {
if strings.HasPrefix(k, needle.PairNamePrefix) || k == "Cache-Control" || k == "Expires" || k == "Content-Disposition" {
if strings.HasPrefix(k, needle.PairNamePrefix) || k == "Cache-Control" || k == "Expires" || k == "Content-Disposition" || k == "Content-Encoding" || (k == "Content-Type" && v[0] != "application/octet-stream") {
entry.Extended[k] = []byte(v[0]) entry.Extended[k] = []byte(v[0])
} }
if k == "Response-Content-Disposition" { if k == "Response-Content-Disposition" {

1
weed/util/http_util.go

@ -23,6 +23,7 @@ func init() {
Transport = &http.Transport{ Transport = &http.Transport{
MaxIdleConns: 1024, MaxIdleConns: 1024,
MaxIdleConnsPerHost: 1024, MaxIdleConnsPerHost: 1024,
DisableCompression: true,
} }
client = &http.Client{ client = &http.Client{
Transport: Transport, Transport: Transport,

Loading…
Cancel
Save