-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathkafka.go
70 lines (61 loc) · 1.39 KB
/
kafka.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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package kafka
import "github.com/Shopify/sarama"
const defaultBufferSize = 256
type Kafka struct {
Producer KafkaProducer
Consumer KafkaConsumer
ConsumerGroup KafkaConsumerGroup
Version sarama.KafkaVersion
}
func getVersion(versionStr string) sarama.KafkaVersion {
switch versionStr {
case "0.8.2.0":
return sarama.V0_8_2_0
case "0.8.2.1":
return sarama.V0_8_2_1
case "0.8.2.2":
return sarama.V0_8_2_2
case "0.9.0.0":
return sarama.V0_9_0_0
case "0.9.0.1":
return sarama.V0_9_0_1
case "0.10.0.0":
return sarama.V0_10_0_0
default:
panic("Unsupported Version")
}
}
func Init(brokerList string) *Kafka {
return InitWithBrokerVersion(brokerList, "0.9.0.0")
}
func InitWithBrokerVersion(brokerList string, version string) *Kafka {
kafka := Kafka{}
kafka.Producer = KafkaProducer{
BrokerList: brokerList,
Key: "",
Partitioner: "random",
Partition: -1,
Verbose: false,
Silent: false,
}
kafka.Consumer = KafkaConsumer{
BrokerList: brokerList,
Verbose: false,
Offset: "newest",
Partitions: "all",
BufferSize: 256, //default
Messages: nil,
Closing: nil,
}
kafka.ConsumerGroup = KafkaConsumerGroup{
BrokerList: brokerList,
Verbose: false,
Offset: "newest",
Partitions: "all",
BufferSize: 256, //default
Messages: nil,
Closing: nil,
Version: getVersion(version),
}
return &kafka
}