Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client represents a client of the message queue. It can be used to spawn any number of consumers or producers.
func (Client) NewConsumer ¶
func (c Client) NewConsumer(ctx context.Context, process func(message []byte) error, opts *ConsumerOptions) (*Consumer, error)
NewConsumer creates a new gq Consumer. It begins pulling messages immediately, and passes each one to the supplied process function
func (Client) NewProducer ¶
NewProducer creates a new gq Producer
type Consumer ¶
type Consumer struct {
// contains filtered or unexported fields
}
Consumer represents a gq consumer
type ConsumerOptions ¶
type ConsumerOptions struct { // PullPeriod is the period messages should be pulled at (default: 50ms). // This can be tuned to achieve the desired throughput/latency tradeoff PullPeriod time.Duration // MaxPullSize is the maximum number of messages to be pulled in one batch (default: 50) MaxBatchSize int // Concurrency is the number of concurrent goroutines to pull messages from (default: num cpus) Concurrency int }
ConsumerOptions represents the options which can be used to tailor producer behaviour
type ProcessFunc ¶
ProcessFunc represents a function which is passed a message to process
type Producer ¶
type Producer struct {
// contains filtered or unexported fields
}
Producer represents a message queue producer
type ProducerOptions ¶
type ProducerOptions struct { // PushPeriod is the period with which messages should be pushed (default: 50ms). // This can be tuned to achieve the desired throughput/latency tradeoff PushPeriod time.Duration // MaxRetryPeriods is the maximum number of push periods to retry a batch of messages for before discarding them (default: 1) MaxRetryPeriods int // Concurrency is the number of concurrent goroutines to push messages from (default: num cpus) Concurrency int }
ProducerOptions represents the options which can be used to tailor producer behaviour
Click to show internal directories.
Click to hide internal directories.