Documentation ¶
Index ¶
- Constants
- func Configure(setter config.Setter) error
- func New(n *node.Node, configs []*ShardConfig) (engine.Engine, error)
- func Plugin(n *node.Node, getter config.Getter) (engine.Engine, error)
- type ChannelID
- type RedisEngine
- func (e *RedisEngine) AddPresence(ch string, uid string, info proto.ClientInfo, expire int) error
- func (e *RedisEngine) Channels() ([]string, error)
- func (e *RedisEngine) History(ch string, limit int) ([]proto.Message, error)
- func (e *RedisEngine) Name() string
- func (e *RedisEngine) Presence(ch string) (map[string]proto.ClientInfo, error)
- func (e *RedisEngine) PublishAdmin(message *proto.AdminMessage) <-chan error
- func (e *RedisEngine) PublishControl(message *proto.ControlMessage) <-chan error
- func (e *RedisEngine) PublishJoin(message *proto.JoinMessage, opts *proto.ChannelOptions) <-chan error
- func (e *RedisEngine) PublishLeave(message *proto.LeaveMessage, opts *proto.ChannelOptions) <-chan error
- func (e *RedisEngine) PublishMessage(message *proto.Message, opts *proto.ChannelOptions) <-chan error
- func (e *RedisEngine) RemovePresence(ch string, uid string) error
- func (e *RedisEngine) Run() error
- func (e *RedisEngine) Shutdown() error
- func (e *RedisEngine) Subscribe(ch string) error
- func (e *RedisEngine) Unsubscribe(ch string) error
- type Shard
- func (e *Shard) AddPresence(ch string, uid string, info proto.ClientInfo, expire int) error
- func (e *Shard) Channels() ([]string, error)
- func (e *Shard) History(ch string, limit int) ([]proto.Message, error)
- func (e *Shard) Presence(ch string) (map[string]proto.ClientInfo, error)
- func (e *Shard) PublishAdmin(message *proto.AdminMessage) <-chan error
- func (e *Shard) PublishControl(message *proto.ControlMessage) <-chan error
- func (e *Shard) PublishJoin(message *proto.JoinMessage, opts *proto.ChannelOptions) <-chan error
- func (e *Shard) PublishLeave(message *proto.LeaveMessage, opts *proto.ChannelOptions) <-chan error
- func (e *Shard) PublishMessage(message *proto.Message, opts *proto.ChannelOptions) <-chan error
- func (e *Shard) RemovePresence(ch string, uid string) error
- func (e *Shard) Run() error
- func (e *Shard) Subscribe(ch string) error
- func (e *Shard) Unsubscribe(ch string) error
- type ShardConfig
Constants ¶
View Source
const ( // RedisSubscribeChannelSize is the size for the internal buffered channels RedisEngine // uses to synchronize subscribe/unsubscribe. It allows for effective batching during bulk // re-subscriptions, and allows large volume of incoming subscriptions to not block when // PubSub connection is reconnecting. Two channels of this size will be allocated, one for // Subscribe and one for Unsubscribe RedisSubscribeChannelSize = 4096 // RedisPubSubWorkerChannelSize sets buffer size of channel to which we send all // messages received from Redis PUB/SUB connection to process in separate goroutine. RedisPubSubWorkerChannelSize = 4096 // Maximum number of channels to include in a single subscribe call. Redis documentation // doesn't specify a maximum allowed but we think it probably makes sense to keep a sane // limit given how many subscriptions a single Centrifugo instance might be handling. RedisSubscribeBatchLimit = 2048 // RedisPublishChannelSize is the size for the internal buffered channel RedisEngine uses // to collect publish requests. RedisPublishChannelSize = 1024 // RedisPublishBatchLimit is a maximum limit of publish requests one batched publish // operation can contain. RedisPublishBatchLimit = 2048 )
View Source
const ( RedisAPIKeySuffix = ".api" RedisControlChannelSuffix = ".control" RedisPingChannelSuffix = ".ping" RedisAdminChannelSuffix = ".admin" RedisMessageChannelPrefix = ".message." RedisJoinChannelPrefix = ".join." RedisLeaveChannelPrefix = ".leave." )
Variables ¶
This section is empty.
Functions ¶
Types ¶
type RedisEngine ¶
RedisEngine uses Redis datastructures and PUB/SUB to manage Centrifugo logic. This engine allows to scale Centrifugo - you can run several Centrifugo instances connected to the same Redis and load balance clients between instances.
func (*RedisEngine) AddPresence ¶
func (e *RedisEngine) AddPresence(ch string, uid string, info proto.ClientInfo, expire int) error
func (*RedisEngine) Channels ¶
func (e *RedisEngine) Channels() ([]string, error)
func (*RedisEngine) Name ¶
func (e *RedisEngine) Name() string
func (*RedisEngine) Presence ¶
func (e *RedisEngine) Presence(ch string) (map[string]proto.ClientInfo, error)
func (*RedisEngine) PublishAdmin ¶
func (e *RedisEngine) PublishAdmin(message *proto.AdminMessage) <-chan error
func (*RedisEngine) PublishControl ¶
func (e *RedisEngine) PublishControl(message *proto.ControlMessage) <-chan error
func (*RedisEngine) PublishJoin ¶
func (e *RedisEngine) PublishJoin(message *proto.JoinMessage, opts *proto.ChannelOptions) <-chan error
func (*RedisEngine) PublishLeave ¶
func (e *RedisEngine) PublishLeave(message *proto.LeaveMessage, opts *proto.ChannelOptions) <-chan error
func (*RedisEngine) PublishMessage ¶
func (e *RedisEngine) PublishMessage(message *proto.Message, opts *proto.ChannelOptions) <-chan error
func (*RedisEngine) RemovePresence ¶
func (e *RedisEngine) RemovePresence(ch string, uid string) error
func (*RedisEngine) Run ¶
func (e *RedisEngine) Run() error
func (*RedisEngine) Shutdown ¶
func (e *RedisEngine) Shutdown() error
func (*RedisEngine) Subscribe ¶
func (e *RedisEngine) Subscribe(ch string) error
func (*RedisEngine) Unsubscribe ¶
func (e *RedisEngine) Unsubscribe(ch string) error
type Shard ¶
Shard has everything to connect to Redis instance.
func (*Shard) AddPresence ¶
func (*Shard) Channels ¶
Requires Redis >= 2.8.0 (http://redis.io/commands/pubsub)
func (*Shard) PublishAdmin ¶
func (e *Shard) PublishAdmin(message *proto.AdminMessage) <-chan error
func (*Shard) PublishControl ¶
func (e *Shard) PublishControl(message *proto.ControlMessage) <-chan error
func (*Shard) PublishJoin ¶
func (e *Shard) PublishJoin(message *proto.JoinMessage, opts *proto.ChannelOptions) <-chan error
func (*Shard) PublishLeave ¶
func (e *Shard) PublishLeave(message *proto.LeaveMessage, opts *proto.ChannelOptions) <-chan error
func (*Shard) PublishMessage ¶
func (*Shard) Unsubscribe ¶
type ShardConfig ¶
type ShardConfig struct { // Host is Redis server host. Host string // Port is Redis server port. Port string // Password is password to use when connecting to Redis database. If empty then password not used. Password string // DB is Redis database number as string. If empty then database 0 used. DB string // MasterName is a name of Redis instance master Sentinel monitors. MasterName string // SentinelAddrs is a slice of Sentinel addresses. SentinelAddrs []string // PoolSize is a size of Redis connection pool. PoolSize int // API enables listening for API queues to publish API commands into Centrifugo via pushing // commands into Redis queue. API bool // NumAPIShards is a number of sharded API queues in Redis to increase volume of commands // (most probably publish) that Centrifugo instance can process. NumAPIShards int // Prefix to use before every channel name and key in Redis. Prefix string // PubSubNumWorkers sets how many PUB/SUB message processing workers will be started. // By default we start runtime.NumCPU() workers. PubSubNumWorkers int // ReadTimeout is a timeout on read operations. Note that at moment it should be greater // than node ping publish interval in order to prevent timing out Pubsub connection's // Receive call. ReadTimeout time.Duration // WriteTimeout is a timeout on write operations WriteTimeout time.Duration // ConnectTimeout is a timeout on connect operation ConnectTimeout time.Duration }
ShardConfig is struct with Redis Engine options.
Click to show internal directories.
Click to hide internal directories.