mirror of
https://github.com/gofiber/storage.git
synced 2025-10-24 08:53:08 +08:00
126 lines
2.7 KiB
Go
126 lines
2.7 KiB
Go
package redis
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"runtime"
|
|
)
|
|
|
|
// Config defines the config for storage.
|
|
type Config struct {
|
|
// Host name where the DB is hosted
|
|
//
|
|
// Optional. Default is "127.0.0.1"
|
|
Host string
|
|
|
|
// Port where the DB is listening on
|
|
//
|
|
// Optional. Default is 6379
|
|
Port int
|
|
|
|
// Server username
|
|
//
|
|
// Optional. Default is ""
|
|
Username string
|
|
|
|
// Server password
|
|
//
|
|
// Optional. Default is ""
|
|
Password string
|
|
|
|
// Database to be selected after connecting to the server.
|
|
//
|
|
// Optional. Default is 0
|
|
Database int
|
|
|
|
// URL standard format Redis URL. If this is set all other config options, Host, Port, Username, Password, Database have no effect.
|
|
//
|
|
// Example: redis://<user>:<pass>@localhost:6379/<db>
|
|
// Optional. Default is ""
|
|
URL string
|
|
|
|
// Either a single address or a seed list of host:port addresses, this enables FailoverClient and ClusterClient
|
|
//
|
|
// Optional. Default is []string{}
|
|
Addrs []string
|
|
|
|
// MasterName is the sentinel master's name
|
|
//
|
|
// Optional. Default is ""
|
|
MasterName string
|
|
|
|
// ClientName will execute the `CLIENT SETNAME ClientName` command for each conn.
|
|
//
|
|
// Optional. Default is ""
|
|
ClientName string
|
|
|
|
// SentinelUsername
|
|
//
|
|
// Optional. Default is ""
|
|
SentinelUsername string
|
|
|
|
// SentinelPassword
|
|
//
|
|
// Optional. Default is ""
|
|
SentinelPassword string
|
|
|
|
// Reset clears any existing keys in existing Collection
|
|
//
|
|
// Optional. Default is false
|
|
Reset bool
|
|
|
|
// TLS Config to use. When set TLS will be negotiated.
|
|
//
|
|
// Optional. Default is nil
|
|
TLSConfig *tls.Config
|
|
|
|
// Maximum number of socket connections.
|
|
//
|
|
// Optional. Default is 10 connections per every available CPU as reported by runtime.GOMAXPROCS.
|
|
PoolSize int
|
|
|
|
// IsClusterMode forces cluster mode even with single address.
|
|
// Useful for AWS ElastiCache Configuration Endpoints.
|
|
//
|
|
// Optional. Default is false
|
|
IsClusterMode bool
|
|
}
|
|
|
|
// ConfigDefault is the default config
|
|
var ConfigDefault = Config{
|
|
Host: "127.0.0.1",
|
|
Port: 6379,
|
|
Username: "",
|
|
Password: "",
|
|
URL: "",
|
|
Database: 0,
|
|
Reset: false,
|
|
TLSConfig: nil,
|
|
PoolSize: 10 * runtime.GOMAXPROCS(0),
|
|
Addrs: []string{},
|
|
MasterName: "",
|
|
ClientName: "",
|
|
SentinelUsername: "",
|
|
SentinelPassword: "",
|
|
IsClusterMode: false,
|
|
}
|
|
|
|
// Helper function to set default values
|
|
func configDefault(config ...Config) Config {
|
|
// Return default config if nothing provided
|
|
if len(config) < 1 {
|
|
return ConfigDefault
|
|
}
|
|
|
|
// Override default config
|
|
cfg := config[0]
|
|
|
|
// Set default values
|
|
if cfg.Host == "" {
|
|
cfg.Host = ConfigDefault.Host
|
|
}
|
|
if cfg.Port <= 0 {
|
|
cfg.Port = ConfigDefault.Port
|
|
}
|
|
return cfg
|
|
}
|