在 k8s 里部署了一套 kafka , 需要对他创建外部的访问地址, 所以用的是 nodeport 的方式, 但是问题在于我想让这个端口不是固定的,而 kafka 的配置 KAFKA_CFG_ADVERTISED_LISTENERS ,这里是固定了 IP 和端口去注册到 zk 的, 有没有兄弟可以提供下思路
1
SKYNE 2023-03-10 10:42:52 +08:00 1
参考: https://artifacthub.io/packages/helm/bitnami/kafka
他的实现思路是专门启动了一个容器,获取对应的 nodeport 端口,然后将对应的信息写入共享的文件中 看起来实现还是挺复杂的 |
2
cmai OP @SKYNE ok ,我先看下,我们用的 kafka 镜像也是基于这个 bitnami 的
我们的场景是这样: 1. 用户在我们这里部署了一套 kafka 2.用户需要外部访问连接来访问 kafka(本地测试用),并且外部访问连接是有时效性(24H/48H 到期),可以随意创建 /删除外部访问连接 我们现在解决的两种方案(都有问题) 1. 用户在部署 kafka 时,就先创建好 nodeport ,当他需要时就开放给他,当到期时就让 nodeport 暂时失效 , 缺点是创建的连接个数在部署时就已经确定了 2.用户在部署后,创建外部连接时,我们创建 nodeport 的同时,去 zk 里把 kafka 注册的信息修改一下,缺点是 kafka 一旦重启,注册的信息会重置 |
3
SKYNE 2023-03-10 12:17:12 +08:00
那这场景比较复杂,
[随意创建 /删除] 可以考虑在初次创建时只能选择是否启用,这样逻辑不就简单点了吗 |