mirror of
https://github.com/redis/go-redis.git
synced 2025-07-29 17:41:15 +03:00
Merge pull request #1377 from davidfu13/master
Make cluster client get updated nodes' addrs
This commit is contained in:
10
cluster.go
10
cluster.go
@ -1015,6 +1015,16 @@ func (c *ClusterClient) loadState(ctx context.Context) (*clusterState, error) {
|
|||||||
return newClusterState(c.nodes, slots, node.Client.opt.Addr)
|
return newClusterState(c.nodes, slots, node.Client.opt.Addr)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* No node is connectable. It's possible that all nodes' IP has changed.
|
||||||
|
* Clear clusterAddrs to let client be able to re-connect using the initial
|
||||||
|
* setting of the addresses (e.g. [redsi-cluster-0:6379, redis-cluster-1:6379]),
|
||||||
|
* which might have chance to resolve domain name and get updated IP address.
|
||||||
|
*/
|
||||||
|
c.nodes.mu.Lock()
|
||||||
|
c.nodes.clusterAddrs = nil
|
||||||
|
c.nodes.mu.Unlock()
|
||||||
|
|
||||||
return nil, firstErr
|
return nil, firstErr
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user