Files
go-zero/core/stores/redis/redisclientmanager.go

66 lines
1.3 KiB
Go
Raw Permalink Normal View History

2020-07-26 17:09:05 +08:00
package redis
import (
"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
red "github.com/redis/go-redis/v9"
"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
func getClient(r *Redis) (*red.Client, error) {
val, err := clientManager.GetResource(r.Addr, func() (io.Closer, error) {
var tlsConfig *tls.Config
if r.tls {
tlsConfig = &tls.Config{
InsecureSkipVerify: true,
}
}
2020-07-26 17:09:05 +08:00
store := red.NewClient(&red.Options{
Addr: r.Addr,
Username: r.User,
Password: r.Pass,
2020-07-26 17:09:05 +08:00
DB: defaultDatabase,
MaxRetries: maxRetries,
MinIdleConns: idleConns,
TLSConfig: tlsConfig,
2020-07-26 17:09:05 +08:00
})
hooks := append([]red.Hook{defaultDurationHook, breakerHook{
brk: r.brk,
}}, r.hooks...)
for _, hook := range hooks {
store.AddHook(hook)
}
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
}