| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- package redis
- import (
- "fmt"
- "net"
- "strings"
- "github.com/go-redis/redis/v7/internal/hashtag"
- "github.com/go-redis/redis/v7/internal/pool"
- )
- func (c *baseClient) Pool() pool.Pooler {
- return c.connPool
- }
- func (c *PubSub) SetNetConn(netConn net.Conn) {
- c.cn = pool.NewConn(netConn)
- }
- func (c *ClusterClient) LoadState() (*clusterState, error) {
- return c.loadState()
- }
- func (c *ClusterClient) SlotAddrs(slot int) []string {
- state, err := c.state.Get()
- if err != nil {
- panic(err)
- }
- var addrs []string
- for _, n := range state.slotNodes(slot) {
- addrs = append(addrs, n.Client.getAddr())
- }
- return addrs
- }
- func (c *ClusterClient) Nodes(key string) ([]*clusterNode, error) {
- state, err := c.state.Reload()
- if err != nil {
- return nil, err
- }
- slot := hashtag.Slot(key)
- nodes := state.slotNodes(slot)
- if len(nodes) != 2 {
- return nil, fmt.Errorf("slot=%d does not have enough nodes: %v", slot, nodes)
- }
- return nodes, nil
- }
- func (c *ClusterClient) SwapNodes(key string) error {
- nodes, err := c.Nodes(key)
- if err != nil {
- return err
- }
- nodes[0], nodes[1] = nodes[1], nodes[0]
- return nil
- }
- func (state *clusterState) IsConsistent() bool {
- if len(state.Masters) < 3 {
- return false
- }
- for _, master := range state.Masters {
- s := master.Client.Info("replication").Val()
- if !strings.Contains(s, "role:master") {
- return false
- }
- }
- if len(state.Slaves) < 3 {
- return false
- }
- for _, slave := range state.Slaves {
- s := slave.Client.Info("replication").Val()
- if !strings.Contains(s, "role:slave") {
- return false
- }
- }
- return true
- }
|