关于 nodeport 和 kafka 的一个问题

2023-03-10 10:19:46 +08:00
cmai  cmai

在 k8s 里部署了一套 kafka , 需要对他创建外部的访问地址, 所以用的是 nodeport 的方式, 但是问题在于我想让这个端口不是固定的,而 kafka 的配置 KAFKA_CFG_ADVERTISED_LISTENERS ,这里是固定了 IP 和端口去注册到 zk 的, 有没有兄弟可以提供下思路

1222 次点击
所在节点   Kubernetes  Kubernetes
3 条回复
SKYNE
SKYNE
2023-03-10 10:42:52 +08:00
参考: https://artifacthub.io/packages/helm/bitnami/kafka
他的实现思路是专门启动了一个容器,获取对应的 nodeport 端口,然后将对应的信息写入共享的文件中
看起来实现还是挺复杂的
cmai
cmai
2023-03-10 11:42:42 +08:00
@SKYNE ok ,我先看下,我们用的 kafka 镜像也是基于这个 bitnami 的

我们的场景是这样:
1. 用户在我们这里部署了一套 kafka
2.用户需要外部访问连接来访问 kafka(本地测试用),并且外部访问连接是有时效性(24H/48H 到期),可以随意创建 /删除外部访问连接

我们现在解决的两种方案(都有问题)
1. 用户在部署 kafka 时,就先创建好 nodeport ,当他需要时就开放给他,当到期时就让 nodeport 暂时失效 , 缺点是创建的连接个数在部署时就已经确定了
2.用户在部署后,创建外部连接时,我们创建 nodeport 的同时,去 zk 里把 kafka 注册的信息修改一下,缺点是 kafka 一旦重启,注册的信息会重置
SKYNE
SKYNE
2023-03-10 12:17:12 +08:00
那这场景比较复杂,
[随意创建 /删除] 可以考虑在初次创建时只能选择是否启用,这样逻辑不就简单点了吗

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/922800

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX