From 862dcbadaefb28417a6a61966424704c4b152bab Mon Sep 17 00:00:00 2001 From: Vladimir Mihailenco Date: Sun, 19 Jul 2020 09:49:00 +0300 Subject: [PATCH] Try 3 random addrs to load commands --- cluster.go | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/cluster.go b/cluster.go index 648baf9a..dcb32349 100644 --- a/cluster.go +++ b/cluster.go @@ -350,7 +350,7 @@ func (c *clusterNodes) Get(addr string) (*clusterNode, error) { node, ok := c.nodes[addr] if ok { - return node, err + return node, nil } node = newClusterNode(c.opt, addr) @@ -358,7 +358,7 @@ func (c *clusterNodes) Get(addr string) (*clusterNode, error) { c.addrs = appendIfNotExists(c.addrs, addr) c.nodes[addr] = node - return node, err + return node, nil } func (c *clusterNodes) get(addr string) (*clusterNode, error) { @@ -1542,22 +1542,33 @@ func (c *ClusterClient) retryBackoff(attempt int) time.Duration { } func (c *ClusterClient) cmdsInfo() (map[string]*CommandInfo, error) { + // Try 3 random nodes. + const nodeLimit = 3 + addrs, err := c.nodes.Addrs() if err != nil { return nil, err } var firstErr error - for _, addr := range addrs { + + perm := rand.Perm(len(addrs)) + if len(perm) > nodeLimit { + perm = perm[:nodeLimit] + } + + for _, idx := range perm { + addr := addrs[idx] + node, err := c.nodes.Get(addr) if err != nil { - return nil, err - } - if node == nil { + if firstErr == nil { + firstErr = err + } continue } - info, err := node.Client.Command(context.TODO()).Result() + info, err := node.Client.Command(c.ctx).Result() if err == nil { return info, nil } @@ -1565,6 +1576,10 @@ func (c *ClusterClient) cmdsInfo() (map[string]*CommandInfo, error) { firstErr = err } } + + if firstErr == nil { + panic("not reached") + } return nil, firstErr }