K8S-volume存储之configmap
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了K8S-volume存储之configmap相关的知识,希望对你有一定的参考价值。
参考技术A ConfigMap顾名思义,是用于保存配置数据的键值对,可以用来保存单个属性,也可以保存配置文件。
ConfigMaps允许你将配置构件与映像内容解耦,以保持容器化应用程序的可移植性。configmap 可以从文件、目录或者 key-value 字符串创建等创建 ConfigMap。也可以通过 kubectl create -f从描述文件创建。可以使用 kubectl create创建命令。创建ConfigMap的方式有4种:
从key-value字符串创建,官方翻译是从字面值中创建ConfigMap。
语法规则
案例
在使用kubectl get获取资源信息的时候,可以通过-o(--output简写形式)指定信息输出的格式,如果 指定的是yaml或者json输出的是资源的完整信息,实际工作中,输出内容过少则得不到我们想要的信息,输 出内容过于详细又不利于快速定位的我们想要找到的内容,其实-o输出格式可以指定为go-template然后 指定一个template,这样我们就可以通过go-template获取我们想要的内容.go-template与 kubernetes无关,它是go语言内置的一种模板引擎.这里不对go-template做过多解释,仅介绍在 kubernetes中获取资源常用的语法,想要获取更多内容,大家可以参考相关资料获取帮助。大家记住是固 定语法即可。
创建一个配置文件:jdbc.properties
语法规则如下:当 --from-file指向一个目录,每个目录中的文件直接用于填充ConfigMap中的 key,key的名称是文件名称,value的值是这个文件的内容。下面的命令读取/data目录下的所有文件
kubectl create configmap cumulx-test --from-file=/data/
kubectl create configmap myjdbcconfigmap --from-file=/data/jdbc.properties
查看configmap详细信息
kubectl describe configmaps myjdbcmap
data/mariadbconfigmap.yml
configmap/mariadbsecret.yml
configmap/mariadb.yml--需要再次整理,加入私服镜像信息
注意修改pod的端口号为3307,service的targetPort端口号为3307
k8sk8s存储配置之ConfigMap
一、ConfigMap简介
Configmap用于保存配置数据,以键值对形式存储。
configMap 资源提供了向 Pod 注入配置数据的方法。
旨在让镜像和配置文件解耦,以便实现镜像的可移植性和可复用性。
典型的使用场景:
- 填充环境变量的值
- 设置容器内的命令行参数
- 填充卷的配置文件
创建Configmap的方式:
- 使用字面值创建
- 使用文件创建
- 使用目录创建
- 编写Configmap的yaml文件创建
如何使用Configmap:
- 通过环境变量的方式直接传递给pod
- 通过在pod的命令行下运行的方式
- 作为volume的方式挂载到pod内
二、创建ConfigMap
01_使用字面值创建
kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2
#key为名称,value为内容
表示创建一个名称为key1,内容为config1的Configmap
也可以在命令后接多个–from-literal以创建多个键值对。
02_使用文件创建
kubectl create configmap my-config-2 --from-file=/etc/resolv.conf
key的名称是文件名称
value的值是这个文件的内容
03_使用目录创建
- 创建目录:
mkdir -p configMap/test
cd configMap/
- 写入测试文件
cp /etc/resolv.conf test/
cp /etc/fstab test/
- 创建
kubectl create configmap my-config-3 --from-file=test
04_编写yaml文件创建
vim cm1.yml
apiVersion: v1
kind: ConfigMap
metadata:
name: cm1-config
data:
db_host: "172.25.2.250"
db_port: "3306"
kubectl apply -f cm1.yml
三、使用ConfigMap
01_通过环境变量的方式直接传递给pod
vim pod1.yml
apiVersion: v1
kind: Pod
metadata:
name: pod1
spec:
containers:
- name: pod1
image: busyboxplus
command: ["/bin/sh", "-c", "env"]
env: # 定义环境变量
- name: key1 #将cm1-config的指定内容db_host赋给pod1的key1
valueFrom:
configMapKeyRef:
name: cm1-config
key: db_host
- name: key2 #将cm1-config的指定内容db_port赋给pod1的key2
valueFrom:
configMapKeyRef:
name: cm1-config
key: db_port
restartPolicy: Never #不重启
kubectl apply -f pod1.yml
查看日志:
02_通过在pod的命令行下运行的方式
vim pod2.yml
apiVersion: v1
kind: Pod
metadata:
name: pod2
spec:
containers:
- name: pod2
image: busyboxplus
command: ["/bin/sh", "-c", "echo $(db_host) $(db_port)"]
envFrom:
- configMapRef:
name: cm1-config
restartPolicy: Never
kubectl apply -f pod2.yml
03_作为volume的方式挂载到pod内
vim pod3.yml
apiVersion: v1
kind: Pod
metadata:
name: pod3
spec:
containers:
- name: pod3
image: busyboxplus
command: ["/bin/sh","-c","ls -l /config/"]
# command: ["/bin/sh","-c","cat /config/db_host"]
volumeMounts:
- name: config-volume
mountPath: /config
volumes:
- name: config-volume
configMap:
name: cm1-config
restartPolicy: Never
示例1:
示例2:
04_热更新
- 修改pod数据,pod不会实时更新,需要等待几秒
- ConfigMap热更新后,并不会触发pod的滚动更新,需要手动触发
- 每次通修改version/config来触发pod滚动更新
- 使用configMap挂载的env环境变量是不会更新的
更新有延迟:
kubectl edit cm cm1-config
kubectl attach pod3 -it
- 设置热更新
vim default.conf
server {
listen 8080;
server_name _;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
}
vim demo.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: demo
spec:
replicas: 1
selector:
matchLabels:
app: myapp
template:
metadata:
labels:
app: myapp
spec:
containers:
- name: myapp
image: myapp:v1
volumeMounts:
- name: config-volume
mountPath: /etc/nginx/conf.d
volumes:
- name: config-volume
configMap:
name: nginx-config
- 使用文件创建cm:设置端口为8080
kubectl create configmap nginx-config --from-file=default.conf
- 创建pod(部署nginx):查询IP地址,并访问8080端口
- 编辑cm配置信息,修改端口为80,cm配置信息成功修改,但容器内部没有同步端口
- 触发滚动更新:端口号成功同步!
kubectl patch deployments.apps demo --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "2021071101"}}}}}'
以上是关于K8S-volume存储之configmap的主要内容,如果未能解决你的问题,请参考以下文章