Linux企业运维——Kubernetes存储之Configmap配置管理

Posted 是大姚呀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux企业运维——Kubernetes存储之Configmap配置管理相关的知识,希望对你有一定的参考价值。

Linux企业运维——Kubernetes(九)存储之Configmap配置管理

1、Configmap简介

Configmap用于保存配置数据,以键值对形式存储。
configMap 资源提供了向 Pod 注入配置数据的方法。
旨在让镜像和配置文件解耦,以便实现镜像的可移植性和可复用性。

典型的使用场景:

  • 填充环境变量的值
  • 设置容器内的命令行参数
  • 填充卷的配置文件

创建ConfigMap的方式有4种:

  • 使用字面值创建
  • 使用文件创建
  • 使用目录创建
  • 编写configmap的yaml文件创建

2、Configmap创建方式

2.1、使用字面值创建

创建一个名为my-config的configmap,通过命令声明键值对,key1的值是config1,key2的值是config2。查看configmap列表,可以看到我们刚创建的my-config并且键值已写进去。

2.2、使用文件创建

创建一个名称为my-config-2的configmap,key是指定的文件的名称,value是文件的内容

2.3、使用目录创建

创建configmap目录,在其中再创建一个test目录,将两个文件复制到test目录

创建名称为my-config-3的configmap,目录中的文件名是key,文件内容是value

查看my-config-3的详细信息,可以看到键值对显示

2.4、编写configmap的yaml文件创建

编写cm1.yaml配置文件,内容如下,然后通过kubectl create -f cm1.yaml创建configmap

查看cm1-config的详细信息,可以看到其中的键值对和在yaml中配置的一样

3、Configmap的使用方法

3.1、通过环境变量的方式直接传递给pod

编辑pod1.yaml,在环境变量里将cm1-config的键db_host名字设为key1,将cm1-config的键db_port名字设为key2

应用配置

查看创建的pod1的日志,可以看到key1和key2

另一种方式,编辑pod2.yml,环境变量来自cm1-config

应用配置,pod1被创建

查看pod1的日志文件,可以看到db_port和db_host键值对

3.2、通过在pod的命令行下运行的方式

编辑pod3.yaml,变量来源于cm1_config,将cm1_config的数据挂载到pod2的/config目录下,应用配置


连接到pod2,查看config目录,可以看到cm1_config中的键值对

3.3、作为volume的方式挂载到pod内

查看现有的configmap,删除前面实验的configmap
‘编辑nginx.conf文件,通过该文件创建configmap,名字为nginxconf

变量来源于nginxconf,将nginxconf的数据挂载到/etc/nginx/conf.d

监听端口为8080

应用配置,查看pod信息及所在节点,可以看到my-nginx的节点ip为10.244.141.212

测试访问10.244.141.212,连接被拒绝,加上8080端口访问成功

查看nginxconf的详细信息看到监听端口是8080

编辑nginxconf,将监听端口改为8000

测试访问10.244.141.212:8000无法访问,再访问10.244.141.212:8080,访问成功,这是因为configmap热更新后,并不会触发相关Pod的滚动更新,需要手动触发

连接到my-nginx容器,切换到/etc/nginx/conf.d目录下,查看nginx.conf看到监听端口为8000

手动更新,现在访问10.244.141.213:8000,成功访问

以上是关于Linux企业运维——Kubernetes存储之Configmap配置管理的主要内容,如果未能解决你的问题,请参考以下文章

Linux企业运维——Kubernetes存储之Volumes配置管理

Linux企业运维——Kubernetes(十三)访问控制

Linux企业运维——Kubernetes(二十)Prometheus监控

Linux企业运维——Kubernetes(二十)Prometheus监控

Linux企业运维——Kubernetes(十四)PSP安全策略

Linux企业运维——Kubernetes(十六)容器资源监控