How to connect to failovered replication Redis when using go-redis library

1k Views Asked by At

In redis cluster mode, even if one of the registered masters shuts down, redirection is performed and the application works without any problem.


package main

import (
    "fmt"
    "github.com/go-redis/redis"
    "log"
    "strconv"
    "time"
)

func main() {
    c := redis.NewClient(&redis.Options{
        Addr:     "127.0.0.1:6379",
        Password: "",
        DB:       0,
    })

    if err := c.Ping().Err(); err != nil {
        panic("Unable to connect to redis " + err.Error())
    }

    c.FlushDB()
    c.FlushAll()

    for i := 1; i <= 7; i++ {
        key := "key" + strconv.Itoa(i)
        ret, err := c.Set(key, "value" + strconv.Itoa(i), 0).Result()
        if err != nil  || ret != "OK"  {
            fmt.Println(err)
            panic("redis set failed")
        }
    }

    for true {
        for i := 1; i <= 7; i++ {
            key := "key" + strconv.Itoa(i)

            val, err := c.Get(key).Result()
            log.Println(key + " : " + val)
            if err == redis.Nil {
                continue
            }
            if err != nil {
                log.Println(err)
                continue
            }
        }
        fmt.Println()
        time.Sleep(1 * time.Second)
    }
}

In a single Redis master-replication configuration, after running the above code, if you shut down master Redis, the following error occurs.

dial tcp 127.0.0.1:6379: connectex: No connection could be made because the target machine actively refused it.

In a single Redis master-replication configuration using go-redis, is there a way to connect the application to replication redis without error even if the master is shut down?

0

There are 0 best solutions below