Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client interface { NewConsumer(appName, consumerName string, concurrency int) (Consumer, error) NewConsumerWithClusterName(currentCluster, sourceCluster, consumerName string, concurrency int) (Consumer, error) NewProducer(appName string) (Producer, error) NewProducerWithClusterName(sourceCluster string) (Producer, error) }
Client is the interface used to abstract out interaction with messaging system for replication
type ClusterConfig ¶
type ClusterConfig struct {
Brokers []string `yaml:"brokers"`
}
ClusterConfig describes the configuration for a single Kafka cluster
type Consumer ¶ added in v0.4.0
type Consumer interface { // Start starts the consumer Start() error // Stop stops the consumer Stop() // Messages return the message channel for this consumer Messages() <-chan Message }
Consumer is the unified interface for both internal and external kafka clients
type KafkaConfig ¶
type KafkaConfig struct { Clusters map[string]ClusterConfig `yaml:"clusters"` Topics map[string]TopicConfig `yaml:"topics"` ClusterToTopic map[string]TopicList `yaml:"cadence-cluster-topics"` Applications map[string]TopicList `yaml:"applications"` }
KafkaConfig describes the configuration needed to connect to all kafka clusters
func (*KafkaConfig) Validate ¶ added in v0.4.0
func (k *KafkaConfig) Validate(checkCluster bool, checkApp bool)
Validate will validate config for kafka
type Message ¶ added in v0.4.0
type Message interface { // Value is a mutable reference to the message's value Value() []byte // Partition is the ID of the partition from which the message was read. Partition() int32 // Offset is the message's offset. Offset() int64 // Ack marks the message as successfully processed. Ack() error // Nack marks the message processing as failed and the message will be retried or sent to DLQ. Nack() error }
Message is the unified interface for a Kafka message
type Producer ¶
type Producer interface { //PublishBatch(msgs []*replicator.ReplicationTask) error PublishBatch(msgs []interface{}) error Publish(msgs interface{}) error Close() error }
Producer is the interface used to send replication tasks to other clusters through replicator
func NewKafkaProducer ¶
NewKafkaProducer is used to create the Kafka based producer implementation
type TopicConfig ¶
type TopicConfig struct {
Cluster string `yaml:"cluster"`
}
TopicConfig describes the mapping from topic to Kafka cluster