You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

50 lines
1.0 KiB

2 years ago
package postman
import (
"context"
2 years ago
"log"
"net"
"strconv"
2 years ago
"test3k/authPostman/internal/config"
2 years ago
"github.com/segmentio/kafka-go"
2 years ago
)
type AuthPostmanServer struct {
2 years ago
kafkaReader *kafka.Reader
ctx context.Context
2 years ago
}
2 years ago
func NewServer(ctx context.Context, config *config.Config, topic string) *AuthPostmanServer {
return &AuthPostmanServer{
kafkaReader: kafka.NewReader(kafka.ReaderConfig{
Topic: topic,
Brokers: []string{net.JoinHostPort(config.Kafka.Host, strconv.Itoa(config.Kafka.Port))},
GroupID: "consumer-group-id",
Partition: 0,
MinBytes: 10e3, // 10KB
MaxBytes: 10e6, // 10MB
}),
ctx: ctx,
}
2 years ago
}
func (s *AuthPostmanServer) GracefulStop() error {
2 years ago
return s.kafkaReader.Close()
}
func (s *AuthPostmanServer) ReadMessage(offset int64) error {
// ...
s.kafkaReader.SetOffset(offset)
//
for {
m, err := s.kafkaReader.ReadMessage(s.ctx)
if err != nil {
return err
}
log.Printf("message at offset %d: %s = %s\n", m.Offset, string(m.Key), string(m.Value))
}
2 years ago
}