首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在go(sarama)中连接kafka (Sarama),消费者无法通过主题获得信息。

在go(sarama)中连接kafka (Sarama),消费者无法通过主题获得信息。
EN

Stack Overflow用户
提问于 2021-12-14 08:18:34
回答 1查看 998关注 0票数 0

我只想跟着一个演示尝试使用卡夫卡在围棋。我可以成功地生成萨拉马的消息,但是当我想要消费这个消息时,我无法得到它。

代码语言:javascript
复制
package main

import (
    "fmt"

    "github.com/Shopify/sarama"
)

// kafka consumer

func main() {
    consumer, err := sarama.NewConsumer([]string{"127.0.0.1:9092"}, nil)
    if err != nil {
        fmt.Printf("fail to start consumer, err:%v\n", err)
        return
    }
    partitionList, err := consumer.Partitions("test") 
    if err != nil {
        fmt.Printf("fail to get list of partition:err%v\n", err)
        return
    }
    fmt.Println(partitionList)
    for partition := range partitionList { 
        pc, err := consumer.ConsumePartition("test", int32(partition), sarama.OffsetNewest)
        if err != nil {
            fmt.Printf("failed to start consumer for partition %d,err:%v\n", partition, err)
            return
        }
        defer pc.AsyncClose()
        go func(sarama.PartitionConsumer) {
            for msg := range pc.Messages() {
                fmt.Printf("Partition:%d Offset:%d Key:%v Value:%v", msg.Partition, msg.Offset, msg.Key, msg.Value)
            }
        }(pc)
    }
}

代码的返回是

代码语言:javascript
复制
[0]
-1

但实际上,我可以通过卡夫卡-控制台-消费者获得信息。

EN

回答 1

Stack Overflow用户

发布于 2021-12-14 09:21:08

我相信你不是在等消息来.

下面是您的代码中包含的问题列表:

  1. defer pc.AsyncClose()会在函数退出时触发,而不是exit.
  2. goroutine正在无处启动的范围.没有阻塞,也没有等待结果的到来。

代码语言:javascript
复制
       go func(sarama.PartitionConsumer) {
            for msg := range pc.Messages() {
                fmt.Printf("Partition:%d Offset:%d Key:%v Value:%v", msg.Partition, msg.Offset, msg.Key, msg.Value)
            }
        }(pc)

  1. 没有把论点传递给goroutine。go func(sarama.PartitionConsumer) { --这只是类型。go func(pc sarama.PartitionConsumer) {.

删除goroutine,如果您想要以hello world为例,只需检查使用者通道。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70345720

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档