/
producer.go
51 lines (39 loc) · 1 KB
/
producer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package kafka
import (
"github.com/Shopify/sarama"
"log"
)
type Producer struct {
syncProducer sarama.SyncProducer
}
// Constructor
func NewProducer(brokers []string) *Producer {
config := sarama.NewConfig()
config.Producer.RequiredAcks = sarama.WaitForAll
config.Producer.Retry.Max = 10
syncProducer, err := sarama.NewSyncProducer(brokers, config)
if err != nil {
log.Fatalln("Failed to start Sarama producer:", err)
panic(err)
}
return &Producer{
syncProducer : syncProducer,
}
}
func (this *Producer) SendMessageToTopic( message []byte, topic string ) error {
// send message
_, _, err := this.syncProducer.SendMessage(&sarama.ProducerMessage {
Topic: topic,
Value: sarama.ByteEncoder(message),
})
if err != nil {
return err
}
log.Println("message sent")
return nil
}
func (this *Producer) Close() {
if err := this.syncProducer.Close(); err != nil {
log.Println("Failed to shut down kafka producer cleanly", err)
}
}