package common_utils import ( "context" "encoding/json" "errors" "github.com/redis/go-redis/v9" "log" "time" ) type RedisHelper struct { rdb redis.UniversalClient isReady bool ctx context.Context } func NewRedisHelper(master string, address ...string) *RedisHelper { r := &RedisHelper{ctx: context.Background()} r.InitialCluster(master, address...) return r //r := &RedisHelper{ctx: context.Background()} //var wg sync.WaitGroup //wg.Add(1) //go func() { // defer wg.Done() // r.InitialCluster(master, address...) //}() //wg.Wait() //return r } func (the *RedisHelper) InitialCluster(master string, address ...string) { var opts *redis.UniversalOptions if master != "" { opts = &redis.UniversalOptions{Addrs: address, MasterName: "mymaster", PoolSize: 10} } else { opts = &redis.UniversalOptions{Addrs: address, PoolSize: 10} } the.rdb = redis.NewUniversalClient(opts) if the.rdb == nil { log.Fatal("Failed to initialize Redis client") } log.Printf("Redis client initialized with addresses: %s", address) the.isReady = true } func (the *RedisHelper) InitialCluster_old(master string, address ...string) { if master != "" { the.rdb = redis.NewUniversalClient(&redis.UniversalOptions{ Addrs: address, MasterName: "mymaster", }) } else { the.rdb = redis.NewUniversalClient(&redis.UniversalOptions{ Addrs: address, }) } log.Printf("redis 初始化完成 %s", address) the.isReady = true } func (the *RedisHelper) Get(key string) string { if the.rdb == nil { log.Println("Redis client is not initialized") return "" } val, err := the.rdb.Get(the.ctx, key).Result() if errors.Is(err, redis.Nil) { log.Printf("%s does not exist", key) } else if err != nil { panic(err) } else { //log.Printf("get key => %s =%s", key, val) } return val } func (the *RedisHelper) GetObj(keys string, addr any) error { err := the.rdb.Get(the.ctx, keys).Scan(addr) if errors.Is(err, redis.Nil) { log.Printf("%s does not exist", keys) } else if err != nil { es := err.Error() log.Printf("err=%s ", es) return err } return nil } func (the *RedisHelper) SetObj(keys string, obj any) error { rs, err := the.rdb.Set(the.ctx, keys, obj, time.Minute*5).Result() log.Printf("rs=%s ", rs) if err != nil { log.Printf("err=%s ", err.Error()) } return err } func (the *RedisHelper) GetLRange(keys string, addr any) error { err := the.rdb.LRange(the.ctx, keys, 0, -1).ScanSlice(addr) if errors.Is(err, redis.Nil) { log.Printf("%s does not exist", keys) } else if err != nil { log.Printf("err=%s ", err.Error()) return err } return nil } func (the *RedisHelper) MGetObj(addr any, keys ...string) error { err := the.rdb.MGet(the.ctx, keys...).Scan(addr) if errors.Is(err, redis.Nil) { log.Printf("%s does not exist", keys) } else if err != nil { log.Printf("err=%s ", err.Error()) return err } return nil } func (the *RedisHelper) HMGetObj(addr any, key, field string) error { rp, err := the.rdb.HMGet(the.ctx, key, field).Result() if errors.Is(err, redis.Nil) { log.Printf("%s does not exist", key) return err } else if err != nil { log.Printf("err=%s ", err.Error()) return err } for _, i := range rp { if v, ok := i.(string); ok { err := json.Unmarshal([]byte(v), addr) if err != nil { return err } } } //todo scan有问题 后续待排查 return nil //err := the.rdb.HMGet(the.ctx, key, field).Scan(addr) //if errors.Is(err, redis.Nil) { // log.Printf("%s does not exist", key) //} else if err != nil { // log.Printf("err=%s ", err.Error()) // return err //} //return nil } func (the *RedisHelper) SRem(key string, members ...string) int64 { return the.rdb.SRem(the.ctx, key, members).Val() } func (the *RedisHelper) SAdd(key string, members ...string) int64 { return the.rdb.SAdd(the.ctx, key, members).Val() }