Documentation ¶
Overview ¶
Package redis is the implementation of the key-value Data Broker client API for the Redis key-value data store. See cn-infra/db/keyval for the definition of the key-value Data Broker client API.
Index ¶
- Constants
- Variables
- func LoadConfig(configFile string) (cfg interface{}, err error)
- type BytesBrokerWatcherRedis
- func (pdb *BytesBrokerWatcherRedis) Delete(match string, opts ...datasync.DelOption) (found bool, err error)
- func (pdb *BytesBrokerWatcherRedis) GetPrefix() string
- func (pdb *BytesBrokerWatcherRedis) GetValue(key string) (data []byte, found bool, revision int64, err error)
- func (pdb *BytesBrokerWatcherRedis) ListKeys(match string) (keyval.BytesKeyIterator, error)
- func (pdb *BytesBrokerWatcherRedis) ListValues(match string) (keyval.BytesKeyValIterator, error)
- func (pdb *BytesBrokerWatcherRedis) NewTxn() keyval.BytesTxn
- func (pdb *BytesBrokerWatcherRedis) Put(key string, data []byte, opts ...datasync.PutOption) error
- func (pdb *BytesBrokerWatcherRedis) Watch(resp func(keyval.BytesWatchResp), closeChan chan string, keys ...string) error
- type BytesConnectionRedis
- func (db *BytesConnectionRedis) Close() error
- func (db *BytesConnectionRedis) Delete(key string, opts ...datasync.DelOption) (found bool, err error)
- func (db *BytesConnectionRedis) GetValue(key string) (data []byte, found bool, revision int64, err error)
- func (db *BytesConnectionRedis) ListKeys(match string) (keyval.BytesKeyIterator, error)
- func (db *BytesConnectionRedis) ListValues(match string) (keyval.BytesKeyValIterator, error)
- func (db *BytesConnectionRedis) NewBroker(prefix string) keyval.BytesBroker
- func (db *BytesConnectionRedis) NewBrokerWatcher(prefix string) *BytesBrokerWatcherRedis
- func (db *BytesConnectionRedis) NewTxn() keyval.BytesTxn
- func (db *BytesConnectionRedis) NewWatcher(prefix string) keyval.BytesWatcher
- func (db *BytesConnectionRedis) Put(key string, data []byte, opts ...datasync.PutOption) error
- func (db *BytesConnectionRedis) Watch(resp func(keyval.BytesWatchResp), closeChan chan string, keys ...string) error
- type BytesWatchDelResp
- type BytesWatchPutResp
- type Client
- type ClientConfig
- type ClusterConfig
- type Deps
- type NodeConfig
- type Option
- type Plugin
- func (p *Plugin) AfterInit() error
- func (p *Plugin) Close() error
- func (p *Plugin) Disabled() (disabled bool)
- func (p *Plugin) Init() (err error)
- func (p *Plugin) NewBroker(keyPrefix string) keyval.ProtoBroker
- func (p *Plugin) NewWatcher(keyPrefix string) keyval.ProtoWatcher
- func (p *Plugin) OnConnect(callback func() error)
- type PoolConfig
- type SentinelConfig
- type TLS
- type Txn
Constants ¶
const GoRedisNil = goredis.Nil
GoRedisNil is error returned by go-redis when Redis replies with nil, .e.g. when key does not exist.
Variables ¶
var DefaultPlugin = *NewPlugin()
DefaultPlugin is a default instance of Plugin.
Functions ¶
func LoadConfig ¶
LoadConfig Loads the given configFile and returns appropriate config instance.
Types ¶
type BytesBrokerWatcherRedis ¶
BytesBrokerWatcherRedis uses BytesConnectionRedis to access the datastore. The connection can be shared among multiple BytesBrokerWatcherRedis. BytesBrokerWatcherRedis allows to define a keyPrefix that is prepended to all keys in its methods in order to shorten keys used in arguments.
func (*BytesBrokerWatcherRedis) Delete ¶
func (pdb *BytesBrokerWatcherRedis) Delete(match string, opts ...datasync.DelOption) (found bool, err error)
Delete calls Delete function of BytesConnectionRedis. Prefix will be prepended to key argument when searching.
func (*BytesBrokerWatcherRedis) GetPrefix ¶
func (pdb *BytesBrokerWatcherRedis) GetPrefix() string
GetPrefix returns the prefix associated with this BytesBrokerWatcherRedis.
func (*BytesBrokerWatcherRedis) GetValue ¶
func (pdb *BytesBrokerWatcherRedis) GetValue(key string) (data []byte, found bool, revision int64, err error)
GetValue calls GetValue function of BytesConnectionRedis. Prefix will be prepended to the key argument when searching.
func (*BytesBrokerWatcherRedis) ListKeys ¶
func (pdb *BytesBrokerWatcherRedis) ListKeys(match string) (keyval.BytesKeyIterator, error)
ListKeys calls ListKeys function of BytesConnectionRedis. Prefix will be prepended to key argument when searching. The returned keys, however, will have the prefix trimmed. When done traversing, you must close the iterator by calling its Close() method.
func (*BytesBrokerWatcherRedis) ListValues ¶
func (pdb *BytesBrokerWatcherRedis) ListValues(match string) (keyval.BytesKeyValIterator, error)
ListValues calls ListValues function of BytesConnectionRedis. Prefix will be prepended to key argument when searching. The returned keys, however, will have the prefix trimmed. When done traversing, you must close the iterator by calling its Close() method.
func (*BytesBrokerWatcherRedis) NewTxn ¶
func (pdb *BytesBrokerWatcherRedis) NewTxn() keyval.BytesTxn
NewTxn creates new transaction. Prefix will be prepended to the key argument.
func (*BytesBrokerWatcherRedis) Put ¶
Put calls Put function of BytesConnectionRedis. Prefix will be prepended to the key argument.
func (*BytesBrokerWatcherRedis) Watch ¶
func (pdb *BytesBrokerWatcherRedis) Watch(resp func(keyval.BytesWatchResp), closeChan chan string, keys ...string) error
Watch starts subscription for changes associated with the selected key. Watch events will be delivered to respChan.
type BytesConnectionRedis ¶
BytesConnectionRedis allows to store, read and watch values from Redis.
func NewBytesConnection ¶
func NewBytesConnection(client Client, log logging.Logger) (*BytesConnectionRedis, error)
NewBytesConnection creates a new instance of BytesConnectionRedis using the provided Client (be it node, or cluster, or sentinel client).
func (*BytesConnectionRedis) Close ¶
func (db *BytesConnectionRedis) Close() error
Close closes the connection to redis.
func (*BytesConnectionRedis) Delete ¶
func (db *BytesConnectionRedis) Delete(key string, opts ...datasync.DelOption) (found bool, err error)
Delete deletes all the keys that start with the given match string.
func (*BytesConnectionRedis) GetValue ¶
func (db *BytesConnectionRedis) GetValue(key string) (data []byte, found bool, revision int64, err error)
GetValue retrieves the value of the key from Redis.
func (*BytesConnectionRedis) ListKeys ¶
func (db *BytesConnectionRedis) ListKeys(match string) (keyval.BytesKeyIterator, error)
ListKeys returns an iterator used to traverse keys that start with the given match string. When done traversing, you must close the iterator by calling its Close() method.
func (*BytesConnectionRedis) ListValues ¶
func (db *BytesConnectionRedis) ListValues(match string) (keyval.BytesKeyValIterator, error)
ListValues returns an iterator used to traverse key value pairs for all the keys that start with the given match string. When done traversing, you must close the iterator by calling its Close() method.
func (*BytesConnectionRedis) NewBroker ¶
func (db *BytesConnectionRedis) NewBroker(prefix string) keyval.BytesBroker
NewBroker creates a new CRUD proxy instance to redis using BytesConnectionRedis. The given prefix will be prepended to key argument in all calls. Specify empty string ("") if not wanting to use prefix.
func (*BytesConnectionRedis) NewBrokerWatcher ¶
func (db *BytesConnectionRedis) NewBrokerWatcher(prefix string) *BytesBrokerWatcherRedis
NewBrokerWatcher creates a new CRUD + KeyValProtoWatcher proxy instance to redis using BytesConnectionRedis. The given prefix will be prepended to key argument in all calls. Specify empty string ("") if not wanting to use prefix.
func (*BytesConnectionRedis) NewTxn ¶
func (db *BytesConnectionRedis) NewTxn() keyval.BytesTxn
NewTxn creates new transaction.
func (*BytesConnectionRedis) NewWatcher ¶
func (db *BytesConnectionRedis) NewWatcher(prefix string) keyval.BytesWatcher
NewWatcher creates a new KeyValProtoWatcher proxy instance to redis using BytesConnectionRedis. The given prefix will be prepended to key argument in all calls. Specify empty string ("") if not wanting to use prefix.
func (*BytesConnectionRedis) Put ¶
Put sets the key/value in Redis data store. Replaces value if the key already exists.
func (*BytesConnectionRedis) Watch ¶
func (db *BytesConnectionRedis) Watch(resp func(keyval.BytesWatchResp), closeChan chan string, keys ...string) error
Watch starts subscription for changes associated with the selected key. Watch events will be delivered to respChan. Subscription can be canceled by StopWatch call.
type BytesWatchDelResp ¶
type BytesWatchDelResp struct {
// contains filtered or unexported fields
}
BytesWatchDelResp is sent when a key-value pair has been removed.
func NewBytesWatchDelResp ¶
func NewBytesWatchDelResp(key string, revision int64) *BytesWatchDelResp
NewBytesWatchDelResp creates an instance of BytesWatchDelResp.
func (*BytesWatchDelResp) GetChangeType ¶
func (resp *BytesWatchDelResp) GetChangeType() datasync.Op
GetChangeType returns "Delete" for BytesWatchPutResp.
func (*BytesWatchDelResp) GetKey ¶
func (resp *BytesWatchDelResp) GetKey() string
GetKey returns the key that has been deleted.
func (*BytesWatchDelResp) GetPrevValue ¶
func (resp *BytesWatchDelResp) GetPrevValue() []byte
GetPrevValue returns nil for BytesWatchDelResp
func (*BytesWatchDelResp) GetRevision ¶
func (resp *BytesWatchDelResp) GetRevision() int64
GetRevision returns the revision associated with the delete operation.
func (*BytesWatchDelResp) GetValue ¶
func (resp *BytesWatchDelResp) GetValue() []byte
GetValue returns nil for BytesWatchDelResp.
type BytesWatchPutResp ¶
type BytesWatchPutResp struct {
// contains filtered or unexported fields
}
BytesWatchPutResp is sent when new key-value pair has been inserted or the value is updated.
func NewBytesWatchPutResp ¶
func NewBytesWatchPutResp(key string, value []byte, prevValue []byte, revision int64) *BytesWatchPutResp
NewBytesWatchPutResp creates an instance of BytesWatchPutResp.
func (*BytesWatchPutResp) GetChangeType ¶
func (resp *BytesWatchPutResp) GetChangeType() datasync.Op
GetChangeType returns "Put" for BytesWatchPutResp.
func (*BytesWatchPutResp) GetKey ¶
func (resp *BytesWatchPutResp) GetKey() string
GetKey returns the key that has been inserted.
func (*BytesWatchPutResp) GetPrevValue ¶
func (resp *BytesWatchPutResp) GetPrevValue() []byte
GetPrevValue returns the value that has been inserted.
func (*BytesWatchPutResp) GetRevision ¶
func (resp *BytesWatchPutResp) GetRevision() int64
GetRevision returns the revision associated with create action.
func (*BytesWatchPutResp) GetValue ¶
func (resp *BytesWatchPutResp) GetValue() []byte
GetValue returns the value that has been inserted.
type Client ¶
type Client interface { // The easiest way to adapt Cmdable interface is just to embed it. goredis.Cmdable // Declare these additional methods to enable access to them through this // interface. Close() error PSubscribe(channels ...string) *goredis.PubSub }
Client is common interface used to adapt all types of Redis clients.
func ConfigToClient ¶
ConfigToClient creates an appropriate client according to the configuration parameter.
func CreateClusterClient ¶
func CreateClusterClient(config ClusterConfig) (Client, error)
CreateClusterClient Creates a client that will connect to a redis cluster.
func CreateNodeClient ¶
func CreateNodeClient(config NodeConfig) (Client, error)
CreateNodeClient creates a client that will connect to a redis node, like master and/or slave.
func CreateSentinelClient ¶
func CreateSentinelClient(config SentinelConfig) (Client, error)
CreateSentinelClient Creates a failover client that will connect to redis sentinels.
type ClientConfig ¶
type ClientConfig struct { // Password for authentication, if required. Password string `json:"password"` // Dial timeout for establishing new connections. Default is 5 seconds. DialTimeout time.Duration `json:"dial-timeout"` // Timeout for socket reads. If reached, commands will fail with a timeout // instead of blocking. Default is 3 seconds. ReadTimeout time.Duration `json:"read-timeout"` // Timeout for socket writes. If reached, commands will fail with a timeout // instead of blocking. Default is ReadTimeout. WriteTimeout time.Duration `json:"write-timeout"` // Connection pool configuration. Pool PoolConfig `json:"pool"` }
ClientConfig is a configuration common to all types of Redis clients.
type ClusterConfig ¶
type ClusterConfig struct { // A seed list of host:port addresses of cluster nodes. Endpoints []string `json:"endpoints"` // Enables read-only queries on slave nodes. EnableReadQueryOnSlave bool `json:"enable-query-on-slave"` // The maximum number of redirects before giving up. // Command is retried on network errors and MOVED/ASK redirects. Default is 16. MaxRedirects int `json:"max-rediects"` // Allows routing read-only commands to the closest master or slave node. RouteByLatency bool `json:"route-by-latency"` ClientConfig }
ClusterConfig Cluster client configuration
type Deps ¶
type Deps struct { infra.PluginDeps StatusCheck statuscheck.PluginStatusWriter Resync *resync.Plugin // inject }
Deps lists dependencies of the redis plugin.
type NodeConfig ¶
type NodeConfig struct { // host:port address of a Redis node Endpoint string `json:"endpoint"` // Database to be selected after connecting to the server. DB int `json:"db"` // Enables read-only queries on slave nodes. EnableReadQueryOnSlave bool `json:"enable-query-on-slave"` // TLS configuration -- only applies to node client. TLS TLS `json:"tls"` // Embedded common client configuration. ClientConfig }
NodeConfig Node client configuration
type Option ¶
type Option func(*Plugin)
Option is a function that can be used in NewPlugin to customize Plugin.
type Plugin ¶
type Plugin struct { Deps // contains filtered or unexported fields }
Plugin implements redis plugin.
func (*Plugin) Disabled ¶
Disabled returns *true* if the plugin is not in use due to missing redis configuration.
func (*Plugin) Init ¶
Init retrieves redis configuration and establishes a new connection with the redis data store. If the configuration file doesn't exist or cannot be read, the returned errora will be of os.PathError type. An untyped error is returned in case the file doesn't contain a valid YAML configuration.
func (*Plugin) NewBroker ¶
func (p *Plugin) NewBroker(keyPrefix string) keyval.ProtoBroker
NewBroker creates new instance of prefixed broker that provides API with arguments of type proto.Message.
func (*Plugin) NewWatcher ¶
func (p *Plugin) NewWatcher(keyPrefix string) keyval.ProtoWatcher
NewWatcher creates new instance of prefixed broker that provides API with arguments of type proto.Message.
type PoolConfig ¶
type PoolConfig struct { // Maximum number of socket connections. // Default is 10 connections per every CPU as reported by runtime.NumCPU. PoolSize int `json:"max-connections"` // Amount of time, in seconds, a client waits for connection if all connections // are busy before returning an error. // Default is ReadTimeout + 1 second. PoolTimeout time.Duration `json:"busy-timeout"` // Amount of time, in seconds, after which a client closes idle connections. // Should be less than server's timeout. // Default is 5 minutes. IdleTimeout time.Duration `json:"idle-timeout"` // Frequency of idle checks. // Default is 1 minute. // When negative value is set, then idle check is disabled. IdleCheckFrequency time.Duration `json:"idle-check-frequency"` }
PoolConfig is a configuration of the go-redis connection pool.
type SentinelConfig ¶
type SentinelConfig struct { // A seed list of host:port addresses sentinel nodes. Endpoints []string `json:"endpoints"` // The sentinel master name. MasterName string `json:"master-name"` // Database to be selected after connecting to the server. DB int `json:"db"` ClientConfig }
SentinelConfig Sentinel client configuration
type TLS ¶
type TLS struct { Enabled bool `json:"enabled"` // enable/disable TLS SkipVerify bool `json:"skip-verify"` // whether to skip verification of server name & certificate Certfile string `json:"cert-file"` // client certificate Keyfile string `json:"key-file"` // client private key CAfile string `json:"ca-file"` // certificate authority }
TLS configures Transport layer security properties.
type Txn ¶
type Txn struct {
// contains filtered or unexported fields
}
Txn allows to group operations into the transaction. Transaction executes multiple operations in a more efficient way in contrast to executing them one by one.
func (*Txn) Commit ¶
Commit commits all operations in a transaction to the data store. Commit is atomic - either all operations in the transaction are committed to the data store, or none of them.