diff options
| author | Konstantin Lebedev <9497591+kmlebedev@users.noreply.github.com> | 2024-11-26 21:33:31 +0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-11-26 08:33:31 -0800 |
| commit | e2e97db917641769b5ddf6c311c406ec63463a10 (patch) | |
| tree | c1f89cb0c8d773cc483073e31d617728c73b0172 /weed/server/master_grpc_server_assign.go | |
| parent | fec88e64eb7c33e73b2e6da2afa99d68db56e495 (diff) | |
| download | seaweedfs-e2e97db917641769b5ddf6c311c406ec63463a10.tar.xz seaweedfs-e2e97db917641769b5ddf6c311c406ec63463a10.zip | |
[master] avoid timeout when assigning for main request with filter by DC or rack (#6291)
* avoid timeout when assigning for main request with filter by DC or rack
https://github.com/seaweedfs/seaweedfs/issues/6290
* use constant NoWritableVolumes
Diffstat (limited to 'weed/server/master_grpc_server_assign.go')
| -rw-r--r-- | weed/server/master_grpc_server_assign.go | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/weed/server/master_grpc_server_assign.go b/weed/server/master_grpc_server_assign.go index a85045f7d..4820de6a2 100644 --- a/weed/server/master_grpc_server_assign.go +++ b/weed/server/master_grpc_server_assign.go @@ -5,6 +5,7 @@ import ( "fmt" "github.com/seaweedfs/seaweedfs/weed/glog" "github.com/seaweedfs/seaweedfs/weed/stats" + "strings" "time" "github.com/seaweedfs/raft" @@ -100,6 +101,9 @@ func (ms *MasterServer) Assign(ctx context.Context, req *master_pb.AssignRequest glog.V(1).Infof("assign %v %v: %v", req, option.String(), err) stats.MasterPickForWriteErrorCounter.Inc() lastErr = err + if (req.DataCenter != "" || req.Rack != "") && strings.Contains(err.Error(), topology.NoWritableVolumes) { + break + } time.Sleep(200 * time.Millisecond) continue } |
