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

42 lines
903 B
Go
Raw 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"
red "github.com/go-redis/redis"
2020-08-08 16:40:10 +08:00
"github.com/tal-tech/go-zero/core/syncx"
2020-07-26 17:09:05 +08:00
)
var clusterManager = syncx.NewResourceManager()
func getCluster(server, pass string) (*red.ClusterClient, error) {
return getClusterWithTLS(server, pass, false)
}
func getClusterWithTLS(server, pass string, tlsEnabled bool) (*red.ClusterClient, error) {
2020-07-26 17:09:05 +08:00
val, err := clusterManager.GetResource(server, func() (io.Closer, error) {
var tlsConfig *tls.Config
if tlsEnabled {
tlsConfig = &tls.Config{
InsecureSkipVerify: true,
}
}
2020-07-26 17:09:05 +08:00
store := red.NewClusterClient(&red.ClusterOptions{
Addrs: []string{server},
Password: pass,
MaxRetries: maxRetries,
MinIdleConns: idleConns,
TLSConfig: tlsConfig,
2020-07-26 17:09:05 +08:00
})
store.WrapProcess(process)
return store, nil
})
if err != nil {
return nil, err
}
return val.(*red.ClusterClient), nil
}