ホームページ  >  記事  >  バックエンド開発  >  **Golang Kafka 10 でコンシューマ グループ オフセットを取得する方法**

**Golang Kafka 10 でコンシューマ グループ オフセットを取得する方法**

DDD
DDDオリジナル
2024-10-25 10:51:02871ブラウズ

**How to Get Consumer Group Offsets in Golang Kafka 10?**

Golang Kafka 10 でのコンシューマ グループ オフセットの取得

Kafka 10 の Golang の Kafka ライブラリ (Sarama) でのコンシューマ グループ サポートの導入により、開発者は、外部ライブラリに依存せずにコンシューマ グループ関連の機能にアクセスできるようになりました。一般的なタスクの 1 つは、コンシューマ グループによって処理されている現在のメッセージ オフセットを取得することです。以前は、これには Kazoo-go などの Zookeeper ベースのソリューションを使用する必要がありました。 Sarama-cluster を使用すると、次のコードを通じてこれを実現できます:

<code class="go">package main

import (
    "context"
    "log"
    "strings"

    "github.com/Shopify/sarama"
)

func main() {
    groupName := "testgrp"
    topic := "topic_name"
    offset, err := GetCGOffset(context.Background(), "localhost:9092", groupName, topic)
    if err != nil {
        log.Fatal(err)
    }
    log.Printf("Consumer group %s offset for topic %s is: %d", groupName, topic, offset)
}

type gcInfo struct {
    offset int64
}

func (g *gcInfo) Setup(sarama.ConsumerGroupSession) error {
    return nil
}

func (g *gcInfo) Cleanup(sarama.ConsumerGroupSession) error {
    return nil
}

func (g *gcInfo) ConsumeClaim(_ sarama.ConsumerGroupSession, claim sarama.ConsumerGroupClaim) error {
    g.offset = claim.InitialOffset()
    return nil
}

func GetCGOffset(ctx context.Context, brokers, groupName, topic string) (int64, error) {
    config := sarama.NewConfig()
    config.Consumer.Offsets.AutoCommit.Enable = false // we're not going to update the consumer group offsets
    client, err := sarama.NewConsumerGroup(strings.Split(brokers, ","), groupName, config)
    if err != nil {
        return 0, err
    }
    info := gcInfo{}
    if err := client.Consume(ctx, []string{topic}, &info); err != nil {
        return 0, err
    }
    return info.offset, nil
}</code>

以上が**Golang Kafka 10 でコンシューマ グループ オフセットを取得する方法**の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。