|
@ -17,9 +17,7 @@ import ( |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
func ReplicatedWrite(masterNode string, s *storage.Store, |
|
|
|
|
|
volumeId needle.VolumeId, n *needle.Needle, |
|
|
|
|
|
r *http.Request) (size uint32, isUnchanged bool, err error) { |
|
|
|
|
|
|
|
|
func ReplicatedWrite(masterNode string, s *storage.Store, volumeId needle.VolumeId, n *needle.Needle, r *http.Request) (isUnchanged bool, err error) { |
|
|
|
|
|
|
|
|
//check JWT
|
|
|
//check JWT
|
|
|
jwt := security.GetJwt(r) |
|
|
jwt := security.GetJwt(r) |
|
@ -33,12 +31,14 @@ func ReplicatedWrite(masterNode string, s *storage.Store, |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
size, isUnchanged, err = s.WriteVolumeNeedle(volumeId, n) |
|
|
|
|
|
|
|
|
if s.GetVolume(volumeId) != nil { |
|
|
|
|
|
isUnchanged, err = s.WriteVolumeNeedle(volumeId, n) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
err = fmt.Errorf("failed to write to local disk: %v", err) |
|
|
err = fmt.Errorf("failed to write to local disk: %v", err) |
|
|
glog.V(0).Infoln(err) |
|
|
glog.V(0).Infoln(err) |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
if len(remoteLocations) > 0 { //send to other replica locations
|
|
|
if len(remoteLocations) > 0 { //send to other replica locations
|
|
|
if err = distributedOperation(remoteLocations, s, func(location operation.Location) error { |
|
|
if err = distributedOperation(remoteLocations, s, func(location operation.Location) error { |
|
@ -75,7 +75,6 @@ func ReplicatedWrite(masterNode string, s *storage.Store, |
|
|
_, err := operation.UploadData(u.String(), string(n.Name), false, n.Data, n.IsGzipped(), string(n.Mime), pairMap, jwt) |
|
|
_, err := operation.UploadData(u.String(), string(n.Name), false, n.Data, n.IsGzipped(), string(n.Mime), pairMap, jwt) |
|
|
return err |
|
|
return err |
|
|
}); err != nil { |
|
|
}); err != nil { |
|
|
size = 0 |
|
|
|
|
|
err = fmt.Errorf("failed to write to replicas for volume %d: %v", volumeId, err) |
|
|
err = fmt.Errorf("failed to write to replicas for volume %d: %v", volumeId, err) |
|
|
glog.V(0).Infoln(err) |
|
|
glog.V(0).Infoln(err) |
|
|
} |
|
|
} |
|
|