aboutsummaryrefslogtreecommitdiff
path: root/weed/server/master_grpc_server_assign.go
diff options
context:
space:
mode:
authorKonstantin Lebedev <9497591+kmlebedev@users.noreply.github.com>2024-11-26 21:33:31 +0500
committerGitHub <noreply@github.com>2024-11-26 08:33:31 -0800
commite2e97db917641769b5ddf6c311c406ec63463a10 (patch)
treec1f89cb0c8d773cc483073e31d617728c73b0172 /weed/server/master_grpc_server_assign.go
parentfec88e64eb7c33e73b2e6da2afa99d68db56e495 (diff)
downloadseaweedfs-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.go4
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
}