2020-07-26 17:09:05 +08:00
|
|
|
package redis
|
|
|
|
|
|
|
|
|
|
import (
|
2021-04-07 20:44:16 +08:00
|
|
|
"crypto/tls"
|
2020-07-26 17:09:05 +08:00
|
|
|
"io"
|
2023-10-26 23:51:28 +08:00
|
|
|
"runtime"
|
2020-07-26 17:09:05 +08:00
|
|
|
|
2024-01-13 22:40:58 +08:00
|
|
|
red "github.com/redis/go-redis/v9"
|
2022-01-04 15:51:32 +08:00
|
|
|
"github.com/zeromicro/go-zero/core/syncx"
|
2020-07-26 17:09:05 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
const (
|
|
|
|
|
defaultDatabase = 0
|
|
|
|
|
maxRetries = 3
|
|
|
|
|
idleConns = 8
|
|
|
|
|
)
|
|
|
|
|
|
2023-10-26 23:51:28 +08:00
|
|
|
var (
|
|
|
|
|
clientManager = syncx.NewResourceManager()
|
|
|
|
|
// nodePoolSize is default pool size for node type of redis.
|
|
|
|
|
nodePoolSize = 10 * runtime.GOMAXPROCS(0)
|
|
|
|
|
)
|
2020-07-26 17:09:05 +08:00
|
|
|
|
2021-04-09 22:40:43 +08:00
|
|
|
func getClient(r *Redis) (*red.Client, error) {
|
|
|
|
|
val, err := clientManager.GetResource(r.Addr, func() (io.Closer, error) {
|
2021-04-08 18:19:36 +08:00
|
|
|
var tlsConfig *tls.Config
|
2021-04-09 22:40:43 +08:00
|
|
|
if r.tls {
|
2021-04-07 20:44:16 +08:00
|
|
|
tlsConfig = &tls.Config{
|
|
|
|
|
InsecureSkipVerify: true,
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-07-26 17:09:05 +08:00
|
|
|
store := red.NewClient(&red.Options{
|
2021-04-09 22:40:43 +08:00
|
|
|
Addr: r.Addr,
|
2025-02-08 12:21:35 +08:00
|
|
|
Username: r.User,
|
2021-04-09 22:40:43 +08:00
|
|
|
Password: r.Pass,
|
2020-07-26 17:09:05 +08:00
|
|
|
DB: defaultDatabase,
|
|
|
|
|
MaxRetries: maxRetries,
|
|
|
|
|
MinIdleConns: idleConns,
|
2021-04-07 20:44:16 +08:00
|
|
|
TLSConfig: tlsConfig,
|
2020-07-26 17:09:05 +08:00
|
|
|
})
|
2024-03-12 12:21:33 +08:00
|
|
|
|
|
|
|
|
hooks := append([]red.Hook{defaultDurationHook, breakerHook{
|
|
|
|
|
brk: r.brk,
|
|
|
|
|
}}, r.hooks...)
|
|
|
|
|
for _, hook := range hooks {
|
2023-03-29 10:28:12 +08:00
|
|
|
store.AddHook(hook)
|
|
|
|
|
}
|
2022-02-09 11:06:06 +08:00
|
|
|
|
2023-10-26 23:51:28 +08:00
|
|
|
connCollector.registerClient(&statGetter{
|
|
|
|
|
clientType: NodeType,
|
|
|
|
|
key: r.Addr,
|
|
|
|
|
poolSize: nodePoolSize,
|
|
|
|
|
poolStats: func() *red.PoolStats {
|
|
|
|
|
return store.PoolStats()
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
|
2020-07-26 17:09:05 +08:00
|
|
|
return store, nil
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return val.(*red.Client), nil
|
|
|
|
|
}
|