企业入门实战--k8s之存储之configMap配置管理、Secret配置管理和Volumes配置管理

企业入门实战--k8s之存储之configMap配置管理、Secret配置管理和Volumes配置管理

一、configMap配置管理

Configmap用于保存配置数据,以键值对形式存储。
configMap资源提供了向Pod 注入配置数据的方法。旨在让镜像和配置文件解耦,以便实现镜像的可移植性和可复用性。
典型的使用场景:·填充环境变量的值
·设置容器内的命令行参数
·填充卷的配置文件

创建configmap

使用字面值指定创建

kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2
kubectl get cm
kubectl describe cm my-config

在这里插入图片描述
在这里插入图片描述
使用文件创建

kubectl create configmap my-config-2 --from-file=/etc/resolv.conf
kubectl get cm
kubectl describe cm my-config-2

在这里插入图片描述
使用目录创建

mkdir configmap
cd configmap/
mkdir test
cp /etc/passwd test/
cp /etc/fstab test/
ls test/

在这里插入图片描述
在这里插入图片描述
编写yaml文件创建
vim cm1.yaml

apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.5.250"
  db_port: "3306"


创建

cat cm1.yaml
kubectl apply -f cm1.yaml
kubectl get cm

在这里插入图片描述

使用configmap

·通过环境变量的方式直接传递给pod
·通过在pod的命令行下运行的方式
·作为volume的方式挂载到pod内

通过环境变量的方式直接传递给pod
cd configmap/
vim pod.yaml

apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: busyboxplus
      command: ["/bin/sh", "-c", "env"]
      env:
        - name: key1
          valueFrom:
            configMapKeyRef:
              name: cm1-config
              key: db_host
        - name: key2
          valueFrom:
            configMapKeyRef:
              name: cm1-config
              key: db_port
  restartPolicy: Never

拉起资源清单,创建节点

kubectl apply -f pod.yaml

kubectl get pod

在这里插入图片描述
通过在pod的命令行下运行的方式
vim pod2.yaml

apiVersion: v1
kind: Pod
metadata:
  name: pod2
spec:
  containers:
    - name: pod2
      image: busyboxplus
      command: ["/bin/sh", "-c", "env"]
      envFrom:
        - configMapRef:
            name: cm1-config
  restartPolicy: Never


拉起资源清单,创建pod2节点

kubectl apply -f pod2.yaml
kubectl get pod

在这里插入图片描述
vim pod3.yaml

apiVersion: v1
kind: Pod
metadata:
  name: pod3
spec:
  containers:
    - name: pod3
      image: busybox
      command: ["/bin/sh", "-c", "echo $(db_host) $(db_port)"]
      envFrom:
        - configMapRef:
            name: cm1-config
  restartPolicy: Never


kubectl apply -f pod3.yaml
kubectl get pod
kubectl logs pod1

在这里插入图片描述
信息来源cm1-config

kubectl describe cm cm1-config

在这里插入图片描述
更新
更新nginx的配置文件,修改端口为8080

server {
   
    listen       8080;
    server_name  _;

    location / {
   
        root /usr/share/nginx/html;
        index  index.html index.htm;
    }
}

在这里插入图片描述
通过文件创建cm

 kubectl create configmap nginxconf --from-file=nginx.conf
kubectl get cm

在这里插入图片描述

kubectl describe cm nginxconf

在这里插入图片描述

编写清单挂载覆盖nginx配置文件
vim nginx.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      app:
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值