登录
首页 >  Golang >  Go问答

Confluence Kafka Go软件包是否与Ubuntu 22.04兼容?

来源:stackoverflow

时间:2024-02-26 08:36:24 461浏览 收藏

大家好,今天本人给大家带来文章《Confluence Kafka Go软件包是否与Ubuntu 22.04兼容?》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我在 ubuntu 20.04 中使用 confluence kafka 包作为 golang 中的数据流服务器,现在我将操作系统更改为 ubuntu 22.04。

现在我收到这些错误:

- kafka.producer/producer.go:18:26: undefined: kafka.Producer
- kafka.producer/producer.go:35:17: undefined: kafka.ConfigMap
- kafka.producer/producer.go:40:30: undefined: kafka.NewProducer
- kafka.producer/producer.go:133:50: undefined: kafka.Message
- kafka.producer/producer.go:134:27: undefined: kafka.TopicPartition
- kafka.producer/producer.go:136:23: undefined: kafka.PartitionAny

但是segmentio包在相同的代码中运行良好。问题是我想使用 confluence 包,因为它具有订阅和取消订阅功能,我觉得它比 segemntio 包更有优势。

有人知道如何解决这个错误吗?


正确答案


由于 github.com/confluenceinc/confluence-kafka-go/v2/kafka 包使用 librdkafka c 库顶部的绑定,因此您必须首先确保 cgo 配置正确。

常见的检查内容是:

  1. 确保 cgo 已启用 (cgo_enabled="1"):

    $ go env CGO_ENABLED
    0
    $ go env -w CGO_ENABLED="1"
  2. 确保 c 编译器可用。运行 go env cc 查看使用的是哪个 c 编译器。

除了检查cgo之外,还需要确保librdkafka可用。请参阅构建标签

  • 默认情况下,将使用捆绑的特定于平台的 librdkafka 静态构建。这在 mac osx 和基于 glibc 的 linux 发行版(例如 ubuntu 和 centos)上开箱即用。
  • -tags musl - 在基于 musl 的 linux 发行版(例如 alpine)上构建时必须指定。将使用 librdkafka 的捆绑静态 musl 构建。
  • -tagsdynamic - 动态链接 librdkafka。共享的 librdkafka 库必须通过其他方式手动安装(apt-get、yum、从源代码构建等)。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>