【Linux39-7】k8s存储配置之ConfigMap
文章目录1. ConfigMap简介2. 创建ConfigMap2.1 使用字面值创建2.2 使用文件创建2.3 使用目录创建2.4 编写yaml文件创建3. 使用ConfigMap3.1 通过环境变量的方式直接传递给pod3.2 通过在pod的命令行下运行的方式3.3 作为volume的方式挂载到pod内4. 热更新1. ConfigMap简介ConfigMap官方文档ConfigMap 是一种
文章目录
1. ConfigMap简介
ConfigMap 是一种 API 对象,用来将非机密性的数据保存到键值对中。使用时, Pods 可以将其用作环境变量、命令行参数或者存储卷中的配置文件。
和其他 Kubernetes 对象都有一个
spec
, 不同的是,ConfigMap 使用data
和binaryData
字段。这些字段能够接收键-值对作为其取值。data
和binaryData
字段都是可选的。data
字段设计用来保存UTF-8
字节序列,而binaryData
则 被设计用来保存二进制数据。
- Configmap用于保存配置数据,以键值对的形式存储
- Configmap资源提供了向Pod诸如配置数据的方法
- 旨在让镜像和配置文件解偶,以便实现镜像的可移植性和可复用性
使用场景:
- 填充环境变量的值
- 设置容器内的命令行参数
- 填充卷的配置文件
创建Configmap的方式:
- 使用字面值创建
- 使用文件创建
- 使用目录创建
- 编写Configmap的yaml文件创建
如何使用Configmap:
- 通过环境变量的方式直接传递给pod
- 通过在pod的命令行下运行的方式
- 作为volume的方式挂载到pod内
2. 创建ConfigMap
2.1 使用字面值创建
创建:
kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2
#key为名称,value为内容
表示创建一个名称为key1,内容为config1的Configmap
也可以在命令后接多个–from-literal以创建多个键值对。
2.2 使用文件创建
kubectl create configmap my-config-2 --from-file=/etc/resolv.conf
# key的名称是文件名称
# value的值是这个文件的内容
2.3 使用目录创建
1.创建目录:
mkdir -p configMap/test
cd configMap/
2.写入测试文件
echo 11111 > test/file1
echo 22222 > test/file2
3.创建
kubectl create configmap my-config-3 --from-file=test
2.4 编写yaml文件创建
kubectl apply -f cm1.yml
# vim cm1.yml
apiVersion: v1
kind: ConfigMap
metadata:
name: cm1-config
data:
db_host: "192.168.17.250"
db_port: "3306"
3. 使用ConfigMap
3.1 通过环境变量的方式直接传递给pod
kubectl apply -f pod1.yml
# vim pod1.yml
apiVersion: v1
kind: Pod
metadata:
name: pod1
spec:
containers:
- name: pod1
image: radial/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 #不重启
查看日志:
3.2 通过在pod的命令行下运行的方式
kubectl apply -f pod2.yml
# pod2.yml
apiVersion: v1
kind: Pod
metadata:
name: pod2
spec:
containers:
- name: pod2
image: radial/busyboxplus
command: ["/bin/sh", "-c", "echo $(db_host) $(db_port)"]
envFrom:
- configMapRef:
name: cm1-config
restartPolicy: Never
3.3 作为volume的方式挂载到pod内
示例1:
# pod3.yml
apiVersion: v1
kind: Pod
metadata:
name: pod3
spec:
containers:
- name: pod3
image: radial/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
示例2:
# pod3.yml
apiVersion: v1
kind: Pod
metadata:
name: pod3
spec:
containers:
- name: pod3
image: radial/busyboxplus
stdin: true
tty: true
volumeMounts:
- name: config-volume
mountPath: /config
volumes:
- name: config-volume
configMap:
name: cm1-config
4. 热更新
- 修改pod数据,pod不会实时更新,需要等待几秒
- ConfigMap热更新后,并不会触发pod的滚动更新,需要手动触发
- 每次通修改version/config来触发pod滚动更新
- 使用configMap挂载的env环境变量是不会更新的
示例:
# default.conf
server {
listen 8080;
server_name _;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
}
# 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
1)使用文件创建cm:设置端口为8080
kubectl create configmap nginx-config --from-file=default.conf
2)创建pod(部署nginx):查询IP地址,并访问8080端口
3)编辑cm配置信息,修改端口为80,cm配置信息成功修改,但容器内部没有同步端口
kubectl edit cm nginx-config
4)触发滚动更新:端口号成功同步!
kubectl patch deployments.apps demo --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "2021030301"}}}}}'
更多推荐
所有评论(0)