1
0
mirror of https://github.com/charlienet/go-mixed.git synced 2025-07-18 08:32:40 +08:00
This commit is contained in:
2022-11-18 16:56:12 +08:00
parent b76be4ce6b
commit bd85140a78
3 changed files with 245 additions and 0 deletions

54
redis/readme.md Normal file
View File

@ -0,0 +1,54 @@
# go-redis 连接选项
连接字符串
redis://<user>:<pass>@<hostname>:<port>/<db>
redis.ParseURL
```go
gClient = redis.NewClient(&redis.Options{
//连接信息
Network: "tcp", //网络类型tcp or unix默认tcp
Addr: "127.0.0.1:6379", //主机名+冒号+端口默认localhost:6379
Password: "", //密码
DB: 0, // redis数据库index
//连接池容量及闲置连接数量
PoolSize: 15, // 连接池最大socket连接数默认为4倍CPU数 4 * runtime.NumCPU
MinIdleConns: 10, //在启动阶段创建指定数量的Idle连接并长期维持idle状态的连接数不少于指定数量
//超时
DialTimeout: 5 * time.Second, //连接建立超时时间默认5秒。
ReadTimeout: 3 * time.Second, //读超时默认3秒 -1表示取消读超时
WriteTimeout: 3 * time.Second, //写超时,默认等于读超时
PoolTimeout: 4 * time.Second, //当所有连接都处在繁忙状态时,客户端等待可用连接的最大等待时长,默认为读超时+1秒。
//闲置连接检查包括IdleTimeoutMaxConnAge
IdleCheckFrequency: 60 * time.Second, //闲置连接检查的周期默认为1分钟-1表示不做周期性检查只在客户端获取连接时对闲置连接进行处理。
IdleTimeout: 5 * time.Minute, //闲置超时默认5分钟-1表示取消闲置超时检查
MaxConnAge: 0 * time.Second, //连接存活时长从创建开始计时超过指定时长则关闭连接默认为0即不关闭存活时长较长的连接
//命令执行失败时的重试策略
MaxRetries: 0, // 命令执行失败时最多重试多少次默认为0即不重试
MinRetryBackoff: 8 * time.Millisecond, //每次计算重试间隔时间的下限默认8毫秒-1表示取消间隔
MaxRetryBackoff: 512 * time.Millisecond, //每次计算重试间隔时间的上限默认512毫秒-1表示取消间隔
//可自定义连接函数
Dialer: func() (net.Conn, error) {
netDialer := &net.Dialer{
Timeout: 5 * time.Second,
KeepAlive: 5 * time.Minute,
}
return netDialer.Dial("tcp", "127.0.0.1:6379")
},
//钩子函数
OnConnect: func(conn *redis.Conn) error { //仅当客户端执行命令时需要从连接池获取连接时,如果连接池需要新建连接时则会调用此钩子函数
fmt.Printf("conn=%v\n", conn)
return nil
},
})
defer gClient.Close()
```