阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Pod 的存储之Configmap

224次阅读
没有评论

共计 3114 个字符,预计需要花费 8 分钟才能阅读完成。

一、Configmap 介绍

​ConfigMap 功能在 Kubernetes1.2 版本中引入,许多应用程序会从配置文件、命令行参数或环境变量中读取配置信息。ConfigMap API 给我们提供了向容器中注入配置信息的机制,ConfigMap 可以被用来保存单个属性,也可以用来保存整个配置文件或者 JSON 二进制大对象。

1、使用目录创建

在我们的 configmap-map 文件夹下有两个文件分别为: test-1 test-2 里面的内容分别为: cat test-1 : enemies=aliens lives=3 enemies.cheat=true enemies.cheat.level=noGoodRotten secret.code.passphrase=UUDDLRLRBABAS secret.code.allowed=true secret.code.lives=30 cat test-2 : color.good=purple color.bad=yellow allow.textmode=true how.nice.to.look=fairlyNice 创建:kubectl create configmap zutuanxue --from-file=configmap-test # —from-file 指定在目录下的所有文件都会被用在 ConfigMap 里面创建一个键值对,键的名字就是文件名,值就是文件的内容

创建完成后我们来看一下信息:

Pod 的存储之 Configmap

通过命令 kubectl get configmaps zutuanxue -o yaml 查看一下完整的信息:

Pod 的存储之 Configmap

2、使用文件创建

我们依然使用 test-1 test-2 这两个文件 kubectl create configmap zutuanxue-1 --from-file=configmap-test/test-2 # —from-file 这个参数可以使用多次,你可以使用两次分别指定上个实例中的那两个配置文件,效果就跟指定整个目录是一样的

我们来看一下效果:

Pod 的存储之 Configmap

3、使用字面值创建

使用文字值创建,利用 —from-literal 参数传递配置信息,该参数可以使用多次,格式如下: kubectl create configmap zutuanxue --from-literal=test.how=hello-word --from-literal=test.type=hi-word

我们来看一下效果:

Pod 的存储之 Configmap

二、Pod 中使用 ConfigMap

1、使用 ConfigMap 来替代环境变量

vim test.yaml apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: hello-word special.type: hi-word #-----------------------------# 分割线 #--------------------------------------# vim test-env.yaml apiVersion: v1 kind: ConfigMap metadata: name: env-config namespace: default data: log_level: INFO #-----------------------------# 分割线 #--------------------------------------# vim test-pod.yaml apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: docker.io/busybox 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: env-config restartPolicy: Never

运行以后我们来看一下结果:

Pod 的存储之 Configmap

2、用 ConfigMap 设置命令行参数

这里我们依然使用 test.yaml 文件内的参数: apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: hello-word special.type: hi-word #-----------------------------# 分割线 #--------------------------------------# vim test-pod-1.yaml apiVersion: v1 kind: Pod metadata: name: dapi-test-pod-1 spec: containers: - name: test-container image: docker.io/busybox 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

运行以后我们来看一下结果:

Pod 的存储之 Configmap

3、通过数据卷插件使用 ConfigMap

这里我们依然使用 test.yaml 文件内的参数: apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: hello-word special.type: hi-word #-----------------------------# 分割线 #--------------------------------------# 在数据卷里面使用这个 ConfigMap,有不同的选项。最基本的就是将文件填入数据卷,在这个文件中,键就是文件名,键值就是文件内容。 #-----------------------------# 分割线 #--------------------------------------# vim test-pod-2.yaml apiVersion: v1 kind: Pod metadata: name: dapi-test-pod-2 spec: containers: - name: test-container image: docker.io/busybox command: [ "/bin/sh", "-c", "sleep 600s" ] volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: special-config restartPolicy: Never

运行以后我们来看一下结果:

Pod 的存储之 Configmap

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-06-09发表,共计3114字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中