如题,使用 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##*-}"]
有没有大佬了解这种情况要怎么设置
1
acrisliu 2020-10-23 13:38:48 +08:00
用 InitContainer 读取 HOSTNAME 再写入对应的配置文件?
|
2
zhenjiachen 2020-10-23 15:37:52 +08:00
同求,我也想知道,搜了一圈没有啥好的解决方案
|
3
JeromeCui 2020-10-23 15:54:59 +08:00
有个环境变量:HOSTNAME=microservice-discovery-0,最后那个 0 就是序号
你可以读这个变量的值或者是读文件 /etc/hostname |
6
zzzbkl 2020-10-23 17:54:11 +08:00 via Android
看看 k8s downward API 是不是你想要的?
|