core/cache/redis/redis.go

67 lines
1.2 KiB
Go
Raw Normal View History

2025-02-07 13:01:38 +08:00
package redis
import (
"context"
"hash/fnv"
"net/url"
"strconv"
"strings"
"git.apinb.com/bsm-sdk/core/vars"
cacheRedis "github.com/redis/go-redis/v9"
)
const (
Nil = cacheRedis.Nil
)
// RedisClient .
type RedisClient struct {
DB int
Client *cacheRedis.Client
Ctx context.Context
2025-10-02 18:06:23 +08:00
memory map[string]any
2025-02-07 13:01:38 +08:00
}
func New(dsn string, hashRadix string) *RedisClient {
arg, err := url.Parse(dsn)
if err != nil {
panic(err)
}
pwd, _ := arg.User.Password()
//get db number,default:0
var db int = 0
arg.Path = strings.ReplaceAll(arg.Path, "/", "")
if arg.Path == "" {
db = Hash(hashRadix)
} else {
db, _ = strconv.Atoi(arg.Path)
}
//connect redis server
client := cacheRedis.NewClient(&cacheRedis.Options{
Addr: arg.Host,
Password: pwd, // no password set
DB: db, // use default DB
Protocol: 3,
})
_, err = client.Ping(context.Background()).Result()
if err != nil {
panic(err)
}
return &RedisClient{
DB: db,
Client: client,
Ctx: context.Background(),
2025-10-02 18:06:23 +08:00
memory: make(map[string]any),
2025-02-07 13:01:38 +08:00
}
}
func Hash(s string) int {
h := fnv.New32a()
2025-03-27 02:49:44 +08:00
h.Write([]byte(strings.ToLower(s)))
2025-02-07 13:01:38 +08:00
return int(h.Sum32()) % vars.RedisShardings
}