k8s 使用 statefulset 如何在 pod 内获取序号并设置到环境变量里

2020-10-23 13:14:12 +08:00
 liunaijie

如题,使用 statefulset,需要为每个 pod 中的配置文件配置不同的值,比如在 pod1 里面的值是 value1,pod2 里面的值是 value2 。 可以创建多个 configmap 来挂载,但是我想使用一个 configmap 然后使用动态替换的方式。

所以想在 stateful-pod-0 中获取 0,然后将其设置为环境变量,在 stateful-pod-1 中获取 1 将其设置为环境变量。配置文件通过读取环境变量为其赋值。

        env:
          - name: REPLICA
            valueFrom:
              fieldRef:
                fieldPath: metadata.name
          - name: SHARD
            value: $(REPLICA##*-) ## get the statefulset pod index, like stateful-0, get 0

我也用其他方法尝试过,比如在启动到时候运行命令,但是这个时候 pod 就起不来了

        command: ["/bin/sh", "-c", "export SHARD=${HOSTNAME##*-}"]

有没有大佬了解这种情况要怎么设置

2827 次点击
所在节点    问与答
6 条回复
acrisliu
2020-10-23 13:38:48 +08:00
用 InitContainer 读取 HOSTNAME 再写入对应的配置文件?
zhenjiachen
2020-10-23 15:37:52 +08:00
同求,我也想知道,搜了一圈没有啥好的解决方案
JeromeCui
2020-10-23 15:54:59 +08:00
有个环境变量:HOSTNAME=microservice-discovery-0,最后那个 0 就是序号
你可以读这个变量的值或者是读文件 /etc/hostname
1423
2020-10-23 16:12:30 +08:00
@JeromeCui 是这,我们也有这么用
liunaijie
2020-10-23 17:39:48 +08:00
@JeromeCui 是的,可以读到这个 hostname,但是要截取后面的序号,没法在 env 里面做转换
zzzbkl
2020-10-23 17:54:11 +08:00
看看 k8s downward API 是不是你想要的?

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

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

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

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

© 2021 V2EX