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(二十)Prometheus监控
Linux企业运维——Kubernetes(二十)Prometheus监控