k8s学习笔记-P37-存储-configmap

教程:尚硅谷Kubernetes教程(K8s入门到精通)_哔哩哔哩_bilibili

笔记摘自视频章节:第七章 Service Ingress


主题

很多应用在其初始化或运行期间要依赖一些配置信息。大多数时候, 存在要调整配置参数所设置的数值的需求。 ConfigMap 是 Kubernetes 用来向应用 Pod 中注入配置数据的方法。

可以理解为一个配置文件管理中心

笔记

根据目录创建

root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu/p37_config_map# cat config_map_path/game.properties

enemies=aliens
lives=3
enemies.cheat=true
enemies.cheat.level=noGoodRotten
secret.code.passphrase=UUDDLRLRBABAS
secret.code.allowed=true
secret.code.lives=30

root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu/p37_config_map# cat config_map_path/ui.properties

color.good=purple
color.bad=yellow
allow.textmode=true
how.nice.to.look=fairlyNice

root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu/p37_config_map# kubectl describe cm jjh-test-config


Name:         jjh-test-config
Namespace:    default
Labels:       <none>
Annotations:  <none>

Data
====
game.properties:
----
enemies=aliens
lives=3
enemies.cheat=true
enemies.cheat.level=noGoodRotten
secret.code.passphrase=UUDDLRLRBABAS
secret.code.allowed=true
secret.code.lives=30


ui.properties:
----
color.good=purple
color.bad=yellow
allow.textmode=true
how.nice.to.look=fairlyNice



BinaryData
====

Events:  <none>
复制代码

根据文件创建

 $ kubectl create configmap game-config-2 --from-file=docs/user- guide/configmap/kubectl/game.properties
 $ kubectl get configmaps game-config-2 -o yaml
root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu/p37_config_map# kubectl create configmap jjh-test-config-fromfile --from-file=./config_map_path/game.properties
configmap/jjh-test-config-fromfile created
root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu/p37_config_map# kubectl describe cm jjh-test-config-fromfile
Name:         jjh-test-config-fromfile
Namespace:    default
Labels:       <none>
Annotations:  <none>

Data
====
game.properties:
----
enemies=aliens
lives=3
enemies.cheat=true
enemies.cheat.level=noGoodRotten
secret.code.passphrase=UUDDLRLRBABAS
secret.code.allowed=true
secret.code.lives=30



BinaryData
====

Events:  <none>
复制代码

使用字面值创建

 $ kubectl create configmap special-config --from-literal=special. how=very --from- literal=special.type=charm
 $ kubectl get configmaps special-config -o yaml

复制代码

实践使用configmap

在env中使用

  • portmap清单
apiVersion: v1
kind: ConfigMap
metadata:
    name: special-config
    namespace: default
data:
    special.how: very
    special.type: charm
---
apiVersion: v1
kind: ConfigMap
metadata:
    name: env-config
    namespace: default
data:
    log_level: INFO
复制代码
  • pod清单
apiVersion: v1
kind: Pod
metadata:
    name: portmap-test-pod
spec:
    containers:
        - name: test-container
          image: wangyanglinux/myapp:v1
          command: [ "/bin/sh", "-c", "env" ]
          env:
              - name: SPECIAL_LEVEL_KEY
                valueFrom:
                    configMapKeyRef:
                        name: special-config
                        key: special.how
              - name: SPECIAL_TYPE_KEY
                valueFrom:
                    configMapKeyRef:
                        name: special-config
                        key: special.type
          envFrom:
              - configMapRef:
                    name
复制代码
  • 查看设置结果

root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu# kubectl logs portmap-test-pod|grep -E "SPECIAL_LEVEL_KE|SPECIAL_TYPE_KEY" SPECIAL_TYPE_KEY=charm SPECIAL_LEVEL_KEY=very

pod命令行参数使用

apiVersion: v1
kind: Pod
metadata:
    name: portmap-test-pord-cmd
spec:
    containers:
        - name: test-
          image: wangyanglinux/myapp:v1
          command: [ "/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ]
          env:
              - name: SPECIAL_LEVEL_KEY
                valueFrom:
                    configMapKeyRef:
                        name: special-config
                        key: special.how
              - name: SPECIAL_TYPE_KEY
                valueFrom:
                    configMapKeyRef:
                        name: special-config
                        key: special.type
    restartPolicy: Never
复制代码

portmapConfig挂载到volume下

  • 资源清单
apiVersion: v1
kind: Pod
metadata:
    name: portmap-test-pod-volume
spec:
    containers:
        - name: test-container
          image: wangyanglinux/myapp:v1
          command: [ "/bin/sh", "-c", "sleep 360; cat /etc/config/special.how" ]
          volumeMounts:
              - name: config-volume
                mountPath: /etc/config
    volumes:
        - name: config-volume
          configMap:
              name: special-config
    restartPolicy: Never

复制代码
  • 应用一下,然后查看配置
root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu# kubectl apply -f p38_portmap_pod_volume.yaml
pod/portmap-test-pod-volume created

root@jjh-k8s-demo-master:~/k8s_yaml/bzhan_shangguigu# kubectl exec portmap-test-pod-volume -- cat  /etc/config/special.how
very

复制代码

configmap配置导出至pod内的文件 这种方式的好处是支持触发 滚动更新,延迟大概10s。如果在env中,不会滚动更新

猜你喜欢

转载自juejin.im/post/7079651562468933669