kubernetes-ConfigMap配置管理详解

一.ConfigMap配置中心简介

1.官方文档

https://kubernetes.io/zh-cn/docs/concepts/configuration/configmap/

ConfigMap是API对象,用于存放明文(非机密性)数据保存到键值对中,可以使用环境变量、命令行参数或者存储卷方式应用到Pod中,ConfigMap相当于Pod中程序的配置文件,通过修改ConfigMap内容来修改程序的配置。

2.ConfigMap局限性

ConfigMap在设计上不是用来存储大量数据的,所以在ConfigMap中保存的数据不能超过1MiB。

二.创建ConfigMap的四种方式

1.第一种:通过命令行创建ConfigMap

创建名为my.cnf的configmap

[root@k8s-master ~]# kubectl create configmap my.cnf --from-literal=datadir=/var/lib/mysql --from-literal=socket=/var/lib/mysql/myqsl.sock

查看configmap详细信息:

[root@k8s-master ~]# kubectl describe cm my.cnf

在这里插入图片描述

2.第二种:通过指定文件创建ConfigMap

首先创建nginx.conf文件,针对nginx.conf文件创建configmap

vim nginx.conf

user  nginx;
worker_processes  auto;
error_log  /var/log/nginx/error.log notice;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  /var/log/nginx/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
    include /etc/nginx/conf.d/*.conf;
}

创建名为nginx.conf的configmap,使用--from-file参数指定文件位置

kubectl create configmap nginx.conf --from-file=www=./nginx.conf

查看详细信息:定义key=www,value=./nginx.conf 中的内容

kubectl describe cm nginx.conf

在这里插入图片描述

3.第三种:通过指定目录创建ConfigMap

首先创建config目录,目录中创建my.cnf配置文件,使用--from-file参数指定config目录

mkdir config && cd config
vim my.cnf

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
symbolic-links=0

[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid
!includedir /etc/my.cnf.d

指定config目录创建configmap

[root@k8s-master config]# kubectl create cm config --from-file=/root/config/

查看详细信息:key会一目录中文名进行命名

[root@k8s-master config]# kubectl describe cm config

在这里插入图片描述

4.第四种:通过YAML资源清单创建ConfigMap

创建my.cnfconfigmap,定义master.cnf,slave.cnf的key

vim  my.cnf.yaml 
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: my.cnf
  labels:
    app: db
data:
  master.cnf: |
   [mysqld]
   datadir=/var/lib/mysql
   socket=/var/lib/mysql/mysql.sock
   symbolic-links=0
   server-id=1
  slave.cnf: |
   [mysqld]
   datadir=/var/lib/mysql
   socket=/var/lib/mysql/mysql.sock
   symbolic-links=0
   server-id=2

执行YAML文件

[root@k8s-master config]# kubectl apply -f my.cnf.yaml 

查看my.cnfconfigmap详细信息
在这里插入图片描述

三.ConfgiMap三种使用方式

1.第一种:使用环境变量引入-configMapKeyRef方式

创建名为nginx-config的configmap

cat nginx-config.yaml 
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: nginx-config
  labels:
    app: nginx
    env: uat
data:
  nginx.conf: |
    user  nginx;
    worker_processes  auto;
    error_log  /var/log/nginx/nginx-error.log notice;
    pid        /var/run/nginx.pid;
    
    
    events {
        worker_connections  1024;
    }
    
    
    http {
        include       /etc/nginx/mime.types;
        default_type  application/octet-stream;
        log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                          '$status $body_bytes_sent "$http_referer" '
                          '"$http_user_agent" "$http_x_forwarded_for"';
        access_log  /var/log/nginx/access.log  main;
        sendfile        on;
        keepalive_timeout  65;
        include /etc/nginx/conf.d/*.conf;
    }

创建deployment资源,容器中引用nginx-config configmap的nginx.conf Key

cat web-nginx.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: web-nginx
  labels:
    app: nginx
    env: uat
spec:
  replicas: 1
  selector:          # 关联标签
    matchLabels:
      app: nginx
      env: uat
  strategy:
    rollingUpdate:   # 更新策略
      maxSurge: 2
      maxUnavailable: 0
  template:
    metadata:
      labels:
        app: nginx
        env: uat
    spec:
      containers:
      - name: nginx
        image: nginx
        imagePullPolicy: IfNotPresent
        env:
        - name: nginxConfig    # 定义环境变量名称
          valueFrom:
            configMapKeyRef:
              name: nginx-config # 指定configmap名称
              key: nginx.conf    # 指定configmap中Key

执行YAML文件:

kubectl apply -f nginx-config.yaml
kubectl apply -f web-nginx.yaml 

查看创建出来的资源信息:

kubectl get pods -l app=nginx
kubectl get configmap nginx-config

在这里插入图片描述
进入 被创建Pod中容器,查看变量信息:

[root@k8s-master config]# kubectl exec -it web-nginx-855f8db6c5-q978b  -- /bin/bash
root@web-nginx-855f8db6c5-q978b:/# printenv

在这里插入图片描述

2.第二种:使用环境变量-envfrom方式

创建名为my.cnf 的configmap,其中定义了两个KEY

cat my.cnf.yaml

apiVersion: v1
kind: ConfigMap
metadata:
  name: my.cnf
data:
  master.cnf: |
   [mysqld]
   datadir=/var/lib/mysql
   socket=/var/lib/mysql/mysql.sock
   symbolic-links=0
   server-id=1
  slave.cnf: |
   [mysqld]
   datadir=/var/lib/mysql
   socket=/var/lib/mysql/mysql.sock
   symbolic-links=0
   server-id=2

创建Deployment,通过envfrom方式指定configmap,这种方式会引用configmap中所有的KEY为系统变量,由于只是演示envFrom方式特性,所有我这边使用 busybox 镜像演示,YAML资源清单如下:

cat envfrom_demo.yaml 
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: envfrom-demo
  namespace: default
spec:
  replicas: 1
  selector:
    matchLabels:
      name: envfrom-demo
  template:
    metadata:
      labels:
        name: envfrom-demo
    spec:
      containers:
      - name: envfrom-demo
        image: busybox:1.28.0
        imagePullPolicy: IfNotPresent
        command: ["/bin/sh", "-c", "sleep 360000"]
        envFrom:
        - configMapRef:
            name: my.cnf   # 指定configmap名称

执行YAML文件:

kubectl apply -f my.cnf.yaml 
kubectl apply -f envfrom_demo.yaml 

查看创建出来的资源信息:

kubectl get pods -l name=envfrom-demo
kubectl get configmap my.cnf

在这里插入图片描述

进入容器查看变量信息:

[root@k8s-master config]# kubectl exec -it envfrom-demo-6ddc9dc44-tph42  -- /bin/sh
/ # printenv

在这里插入图片描述

3.第三种:使用volume卷挂载

前两种都是使用环境变量方式引用配置的不会经常使用,最常用的还是使用卷挂载方式!

创建名为web的configmap,定义了两个KEY,分别为:nginx_8080.conf、nginx_9090.conf

cat web-config.yaml 
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: web
data:
  nginx_8080.conf: |
    server {
    listen 8080;
     location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
         }
    }
  nginx_9090.conf: |
    server {
    listen 9090;
     location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
         }
    }

使用nginx镜像,创建Deployment,并使用挂载configmap

cat web.yaml 

---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: web-nginx
spec:
  replicas: 1
  selector:      
    matchLabels:
      app: web
  template:
    metadata:
      labels:
        app: web
    spec:
      volumes:
      - name: web-config
        configMap:           # 定义卷,使用名为web的configmap
          name: web
      containers:
      - name: nginx
        image: nginx
        imagePullPolicy: IfNotPresent
        volumeMounts:
        - name: web-config  # 挂载卷
          mountPath: /etc/nginx/conf.d/nginx_9090.conf   # 挂载路径
          subPath: nginx_9090.conf  # 只挂载configmap中的nginx_9090.confkey

执行YAML资源清单:

kubectl apply -f web-config.yaml
kubectl apply -f web.yaml

配置文件端口改为9090,请求Nginx的9090端口,作为验证:

[root@k8s-master config]# kubectl get pod -owide
NAME                               READY   STATUS    RESTARTS      AGE    IP            NODE        NOMINATED NODE   READINESS GATES
web-nginx-596bdbd7bd-4z8tm         1/1     Running   0             109m   10.244.1.43   k8s-node2   <none>           <none>
[root@k8s-master config]# curl 10.244.1.43:9090

在这里插入图片描述
通过9090端口访问到nginx。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值