Skip to content

huangfu/kafka-go

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Kafka Go

Kafka library in Go. This builds on Sarama but offers a few differences:

  • Doesn't use Kafka consumer groups.
  • Exposes a stream-based API
  • Builds a low-level interface that can be composed with higher-level components.

Getting Started

import "github.com/segmentio/kafka-go"

ctx := context.Background()

reader, err := kafka.NewReader(ReaderConfig{
  Brokers: []string{"localhost:9092"},
  Topic: "events",
  Partition: 0,
})

if err != nil {
  panic(err)
}

offset, err := reader.Seek(ctx, OffsetOldest)
if err != nil {
  panic(err)
}

for {
  msg, err := reader.Read(ctx)
  if err != nil {
    panic(err)
  }

  fmt.Println("key: %s value: %s offset: %d", msg.Key, msg.Value, msg.Offset)
}

reader.Close()

Creating a Group Reader

Instead of manually assigning partitions to each reader we can automate it with groups. Just give it the number of partitions there are and each reader will take ownership of one.

config := kafka.GroupConfig{
  Name: "my-group-name",
  // Consul address
  Addr: "http://localhost:8500",
  Brokers: []string{"localhost:9092"},
  Topic: "foobar",
  Partitions: 100,

  // ...
}

reader, err := kafka.NewGroupReader(config)
if err != nil {
  panic(err)
}

offset, err := reader.Seek(ctx, kafka.OffsetOldest)
// ...

msg, err := reader.Read(ctx)
// ...

defer reader.Close()

Running Tests

govendor test +local

License

MIT

About

Kafka library in Go

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%