-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathredis_cli.go
75 lines (66 loc) · 1.91 KB
/
redis_cli.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package timerstore
import (
"fmt"
"time"
"gopkg.in/redis.v3"
)
// Config is needed when initializing redis client
type Config struct {
Host string
Port string
Password string
Type string
PoolSize int
PoolTimeout int
}
// DClient 是redis 集群或单机模式的客户端的抽象接口
type DClient interface {
Set(string, interface{}, time.Duration) *redis.StatusCmd
Get(string) *redis.StringCmd
HGetAllMap(string) *redis.StringStringMapCmd
HMSetMap(string, map[string]string) *redis.StatusCmd
LPush(string, ...string) *redis.IntCmd
LTrim(string, int64, int64) *redis.StatusCmd
Del(keys ...string) *redis.IntCmd
ZAdd(key string, members ...redis.Z) *redis.IntCmd
ZRange(key string, start, stop int64) *redis.StringSliceCmd
ZRem(key string, members ...string) *redis.IntCmd
}
// DaClient 全局共用redis client
var DaClient DClient
// NewRedisClient initializes a redis client
func NewRedisClient(config *Config) (client DClient, err error) {
if config.Type == "cluster" {
options := &redis.ClusterOptions{
Addrs: []string{config.Host + ":" + config.Port},
Password: config.Password,
PoolSize: config.PoolSize,
PoolTimeout: time.Duration(config.PoolTimeout) * time.Second,
}
client = redis.NewClusterClient(options)
} else if config.Type == "client" {
options := &redis.Options{
Addr: config.Host + ":" + config.Port,
Password: config.Password,
PoolSize: config.PoolSize,
PoolTimeout: time.Duration(config.PoolTimeout) * time.Second,
}
client = redis.NewClient(options)
} else {
err = fmt.Errorf("Redis init failed, redistype not define")
return
}
return
}
// InitRedis 初始化DaClient
func InitRedis(config *Config) (err error) {
DaClient, err = NewRedisClient(config)
return
}
// NewZ 生成redis.Z对象
func NewZ(score int64, member interface{}) redis.Z {
return redis.Z{
Score: float64(score),
Member: member,
}
}