kafka version
kafka_2.11-2.3.1
Follow the guide to start kafka server, on this version 2.3.1,
kafa is using zookeeper service to maintain meta-data information.
start zookeeper and kafka service in local
| 1 | bin/zookeeper-server-start.sh config/zookeeper.properties | 
we can produce messages
| 1 | bin/kafka-console-producer.sh --broker-list localhost:9092 --topic test | 
consumer groups
each group can consume same messages at the same time, this could be widely used in a lot of applications,
| 1 | sales group for example, | 
if we want to reset offset of one consumer group, messages can be re-consumed again, for example,
| 1 | ./bin/kafka-consumer-groups.sh --bootstrap-server localhost:9092 --topic test --group "sales-group1" --reset-offsets --to-earliest --execute | 
About further understanding of kafka topic and partitions
references1
https://dzone.com/articles/apache-kafka-topic-architecture-amp-partitions
Kafka in Golang
opensources
"github.com/Shopify/sarama"
1
2
3
4
5
6
7
8
9
10
	cfg := sarama.NewConfig()
switch os.Getenv("KAKFA_APIVERSION") {
case "V0_11_0_0":
	cfg.Version = sarama.V0_11_0_0
default:
	cfg.Version = sarama.V1_0_0_0
}
c, err := sarama.NewClient([]string{d.addr}, cfg)
1
2
3
4
5
6
7
	d.producerWithPartition.Input() <- &sarama.ProducerMessage{
	Topic:     l.Topic,
	Key:       sarama.StringEncoder(l.Key),
	Partition: int32(getPartition(l.Key, num)),
	Value:     sarama.StringEncoder(l.Data),
	Headers:   header,
}
the other good opensource is1
"github.com/segmentio/kafka-go"