configmap解释

在k8s运行期间会有一些依赖的配置文件,他们存在宿主机中的一个目录中或者代码里,如果配置放生变化,pod在另一台服务器启动,在没有这些配置的时候,可能会导致pod无法正常运行,如果pod没有挂载配置文件,修改配置会更加麻烦,configmap用于解决此类问题
有了configmap后,就可以实现配置与pod分离,哪怕pod挂了,重启的pod依然会读到这个配置文件,免除人工干预和业务不可用的状况出现

官方文档: https://kubernetes.io/zh/docs/concepts/configuration/configmap/

configmap例子

configmap示例:

apiVersion: v1
kind: ConfigMap
metadata:
name: game-demo
data:
# property-like keys; each key maps to a simple value
player_initial_lives: "3"
ui_properties_file_name: "user-interface.properties" # file-like keys
game.properties: |
enemy.types=aliens,monsters
player.maximum-lives=5
user-interface.properties: |
color.good=purple
color.bad=yellow
allow.textmode=true

1. configmap基于目录创建

#创建comfigmap文件夹
mkdir -p configmap/conf 写入演示配置:
[root@k8s-master01 ~]# cat configmap/conf/game.conf
lives=3
seret.code=ture [root@k8s-master01 ~]# cat configmap/conf/game2.conf
color.good=purple
user=tomcat [root@k8s-master01 configmap]# kubectl create configmap cmfromdir --from-file=conf/
configmap/cmfromdir created #检查
[root@k8s-master01 configmap]# kubectl get configmaps
NAME DATA AGE
cmformdir 3 5s #查看:
[root@k8s-master01 conf]# kubectl get cm cmfromdir -o yaml
apiVersion: v1
data:
game.conf: |
lives=3
seret.code=ture
game2.conf: |
color.good=purple
user=tomcat
kind: ConfigMap
metadata:
creationTimestamp: "2021-07-24T09:57:20Z"
name: cmfromdir
namespace: default
resourceVersion: "1533829"
uid: 45a67622-0ec0-4862-af9a-3fd29ea63653 #查看:
[root@k8s-master01 configmap]# kubectl describe configmaps cmfromdir
Name: cmfromdir
Namespace: default
Labels: <none>
Annotations: <none> Data
====
game.conf:
----
lives=3
seret.code=ture
test_env=chenleilei game2.conf:
----
color.good=purple
user=tomcat Events: <none>

2. configmap基于文件创建

# 如果一个目录中有很多配置文件,只需要其中一个配置文件,则可以使用以下方法

# 如 创建一个 redis配置文件
cat conf/redis.conf
password redis123 [root@k8s-master01 conf]# kubectl create cm cmfromfile --from-file=redis.conf
configmap/cmfromfile created 检查:
[root@k8s-master01 conf]# kubectl get cm cmfromfile -o yaml
apiVersion: v1
data:
redis.conf: |
password redis123 #检查此处是否存在值
kind: ConfigMap
metadata:
creationTimestamp: "2021-07-27T03:50:25Z"
name: cmfromfile
namespace: default
resourceVersion: "1776478"
uid: 575ae214-c1eb-43b2-8201-715921563de1 #检查这个目录:
[root@k8s-master01 conf]# ls
game2.conf game.conf redis.conf 通过: kubectl create cm cmfromfile --from-file=redis.conf
只把redis.conf 创建了。这是基于文件创建的办法。

3. 自定义配置文件名称

#单个文件创建自定义名

kubectl create configmap [configmap名] --from-file=[自定义的文件名字]=[需要自定义的文件] 

[root@k8s-master01 conf]# kubectl create cm cmspecialname --from-file=game-conf=game.conf
configmap/cmspecialname created [root@k8s-master01 conf]# kubectl get cm
NAME DATA AGE
cmspecialname 1 4s [root@k8s-master01 conf]# kubectl get configmaps cmspecialname -o yaml
apiVersion: v1
data:
game-conf: | ### 这里的配置文件名称已经改变了[这是k8s中的一个功能,但并不常用,知道就可以了]
lives=3
seret.code=ture
test_env=chenleilei
kind: ConfigMap
metadata:
creationTimestamp: "2021-07-29T02:49:46Z"
name: cmspecialname
namespace: default
resourceVersion: "1864212"
uid: 29536467-8f0c-4547-b9d6-aa8ecd1e0e51 #自定义多个文件名称,如下:
[root@k8s-master01 conf]# kubectl create cm cmspecialname3 --from-file=game-conf=game.conf --from-file=redis-conf=redis.conf
configmap/cmspecialname2 created #这样就把 game.conf和redis.conf分别定义为了 game-conf 与 redis-conf #查看configmap
[root@k8s-master01 conf]# kubectl get cm
NAME DATA AGE
cmformdir 3 19m
cmspecialname 1 3m18s
cmspecialname3 2 12s #新名称
envfromliteral 2 46h
kube-root-ca.crt 1 27d
redis-conf 1 40h

4. 选择命名空间创建configmap

# #通常,在不同的命名空间下也会有配置引用,但是不同命名空间无法相互使用configmap,所以需要在对应命名空间创建configmap
# configmap也可以创建在不同的命名空间下面,如在kube-public空间创建:
[root@k8s-master01 conf]# kubectl create cm cmspecialname3 --from-file=game-conf=game.conf --from-file=redis-conf=redis.conf -n kube-public
configmap/cmspecialname3 created [root@k8s-master01 conf]# kubectl get configmaps cmspecialname3 -o yaml
apiVersion: v1
data:
game-conf: |
lives=3
seret.code=ture
test_env=chenleilei
redis-conf: |
password redis123
kind: ConfigMap
metadata:
creationTimestamp: "2021-07-28T08:07:55Z"
name: cmspecialname3
namespace: default
resourceVersion: "1838693"
uid: a4ecd8c5-b8da-40cb-bc55-ec369b7f482f #这样会在 kube-public 命名空间创建 redis.conf 配置文件,检查:
[root@k8s-master01 conf]# kubectl get cm -n kube-public
NAME DATA AGE
cluster-info 1 25d
cmspecialname2 2 81s # 新建的configmap
kube-root-ca.crt 1 25d

5. 基于env文件创建configmap [--from-env-file ]

以env文件创建configmap: ‘--from-env-file’

#基于环境变量创建configmap [适用于环境变量较多的情况]
[root@k8s-master01 conf]# cat game.conf
lives=3
seret.code=ture [root@k8s-master01 conf]# kubectl create cm gameenvcm --from-env-file=game.conf
configmap/gameenvcm created [root@k8s-master01 conf]# kubectl get cm gameenvcm -o yaml
apiVersion: v1
data:
lives: "3"
seret.code: ture
test_env: chenleilei
kind: ConfigMap
metadata:
creationTimestamp: "2021-07-29T03:01:49Z"
name: gameenvcm
namespace: default
resourceVersion: "1865617"
uid: ee31d97a-48c2-48dd-b971-8f7b45255763

6. 基于命令行创建多个变量

--from-literal=

[root@k8s-master01 conf]# kubectl create cm envfromliteral --from-literal=level=INFO --from-literal=PASSWORD=redis123
configmap/envfromliteral created [root@k8s-master01 conf]# kubectl get cm envfromliteral -o yaml
apiVersion: v1
data:
PASSWORD: redis123
level: INFO
kind: ConfigMap
metadata:
creationTimestamp: "2021-07-27T04:20:49Z"
name: envfromliteral
namespace: default
resourceVersion: "1780015"
uid: 9f212cfc-2cce-42d5-9d62-bced22e869e4

7. 基于yaml文件创建configmap

[root@k8s-master01 conf]# cat cm.yaml apiVersion: v1kind: ConfigMapmetadata:  name: game-demodata:  # 类属性键;每一个键都映射到一个简单的值  player_initial_lives: "3"  ui_properties_file_name: "user-interface.properties"  # 类文件键  game.properties: |    enemy.types=aliens,monsters    player.maximum-lives=5      user-interface.properties: |    color.good=purple    color.bad=yellow    allow.textmode=true    #查看:[root@k8s-master01 conf]# kubectl create -f cm.yaml configmap/game-demo created#这种方式创建,在kubectl edit编辑的时候不太好改,会出现串行的问题。建议使用配置文件的方式来创建configmap问题 如:[root@k8s-master01 conf]# kubectl edit cm game-demo # Please edit the object below. Lines beginning with a '#' will be ignored,# and an empty file will abort the edit. If an error occurs while saving this file will be# reopened with the relevant failures.#apiVersion: v1data:  game.properties: "enemy.types=aliens,monsters\nplayer.maximum-lives=5    \n"   #会出现 \n 这种东西  player_initial_lives: "3"  ui_properties_file_name: user-interface.properties  user-interface.properties: |    color.good=purple    color.bad=yellow    allow.textmode=truekind: ConfigMapmetadata:  creationTimestamp: "2021-07-27T04:26:35Z"  name: game-demo  namespace: default  resourceVersion: "1780686"  uid: 270d373e-8485-4a15-970d-06de6728dae7

创建configmap总结:

#创建configmap的几种办法:kubectl create configmap -hkubectl create cm cmfromdir --from-file=conf/kubectl create cm cmfromfile --from-file=conf/redis.conf kubectl create cm cmspecialname --from-file=game-conf=game.confkubectl create cm cmspecialname2 --from-file=game-conf=game.conf  --from-file=redis-conf=redis.confkubectl create cm gameenvcm --from-env-file=game.confkubectl  create cm envfromliteral --from-literal=level=INFO --from-literal=PASSWORD=redis123kubectl  create -f cm.yaml

kubernetes configmap配置方法的更多相关文章

  1. kubernetes实战-配置中心(一)configmap资源

    在我们的环境中测试使用configmap资源,需要先对我们的环境进行一些准备,首先将dubbo服务调整为0个pod ,然后把zookeeper进行拆分: 拆分zk环境,模拟测试环境跟生产环境: 停止z ...

  2. Kubernetes(k8s)配置文件管理:ConfigMap

    目录 一.系统环境 二.前言 三.ConfigMap概览 四.创建ConfigMap 五.ConfigMap的使用 5.1 以环境变量的方式使用ConfigMap 5.2 以卷的方式使用ConfigM ...

  3. kubernetes Configmap secret的使用

    kubernetes configmap 核心作用是让配置信息和镜像解耦,pod可以使用configmap的数据生成配置文件.如果后端的pod配置文件要改变时,只需要更改下configmap里面的数据 ...

  4. configmap使用方法

    说明: kubernetes统一配置管理方案configmap,实现将配置文件从容器镜像中解耦,增强应用的可移植性.数据可直接注入pod对象中,为容器所使用,注入方式有挂载为存储卷和传递为环境变量两种 ...

  5. docker网络配置方法总结

    docker启动时,会在宿主主机上创建一个名为docker0的虚拟网络接口,默认选择172.17.42.1/16,一个16位的子网掩码给容器提供了65534个IP地址.docker0只是一个在绑定到这 ...

  6. 在容器服务kubernetes上配置https

    当前容器服务Kubernetes集群支持多种应用访问的形式,最常见形式如SLB:Port,NodeIP:NodePort和域名访问等.但是Kubernetes集群默认不支持HTTPS访问,如果用户希望 ...

  7. Kubernetes configMap(配置文件存储)

    Kubernetes configMap(配置文件存储) 官方文档:https://kubernetes.io/docs/tasks/configure-pod-container/configure ...

  8. CentOS 6.3下Samba服务器的安装与配置方法(图文详解)

    这篇文章主要介绍了CentOS 6.3下Samba服务器的安装与配置方法(图文详解),需要的朋友可以参考下   一.简介  Samba是一个能让Linux系统应用Microsoft网络通讯协议的软件, ...

  9. CentOS防火墙iptables的配置方法详解

    CentOS系统也是基于linux中的它的防火墙其实就是iptables了,下面我来介绍在CentOS防火墙iptables的配置教程,希望此教程对各位朋友会有所帮助. iptables是与Linux ...

  10. Wampserver 2.5 多站点配置方法

    写在开头:本文适用于wampserver2.5版本,和wamp的老版本配置有语法上的区别,笔者正是因为被老版本的配置办法给整迷糊了所以才总结了一篇针对2.5版本的配置方法,如果您还停留在1.x或着已经 ...

随机推荐

  1. centos 6.4更新163源

    centos 6.4更新163源   1. 备份现在的源文件    mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base. ...

  2. css test-align 和 margin 居中什么区别

    共同点 test-align 和margin 都可以居中: test-align:Center. margin: 0 auto. 很好但是看下区别: <div style="backg ...

  3. 2024-04-17:用go语言,欢迎各位勇者莅临力扣城,本次的挑战游戏名为「力扣泡泡龙」。 游戏的起点是一颗形状如二叉树的泡泡树,其中每个节点的值代表该泡泡的分值。勇者们有一次机会可以击破一个节点泡

    2024-04-17:用go语言,欢迎各位勇者莅临力扣城,本次的挑战游戏名为「力扣泡泡龙」. 游戏的起点是一颗形状如二叉树的泡泡树,其中每个节点的值代表该泡泡的分值.勇者们有一次机会可以击破一个节点泡 ...

  4. Vue3 解构赋值失去响应式引发的思考

    前言 vue3发布以来经历两年风头正盛,现在大有和react 平分秋色的势头,我们知道他是基于proxy 实现响应式的能力, 解决了vue2所遗留下来的一些问题,同时也正由于proxy的特性,也提高了 ...

  5. etcd 集群安装

    1.环境准备 下载安装包:https://github.com/etcd-io/etcd/releases/ 这里下载的安装包为:etcd-v3.5.9-linux-amd64.tar.gz,即我们当 ...

  6. Oracle 数据库误删操作闪回

    Oracle 数据库误删操作闪回 闪回功能是内置的,类似于服务器快照,看运气要在的数据在不在 select * from testtable as of timestamp to_timestamp( ...

  7. Dubbo3.0|阿里巴巴服务框架三位一体的选择与实践

    ​简介: 服务框架就像铁路的铁轨一样,是互通的基础,只有解决了服务框架的互通,才有可能完成更高层的业务互通,所以用相同的标准统一,合二为一并共建新一代的服务框架是必然趋势.Dubbo3.0 是 Dub ...

  8. 提示工程(Prompt Engineering)将ChatGPT调教为傲娇猫娘~喵

    Prompt Engineering(提示工程)是指通过设计精心构造的提示(prompt)或者输入,来引导大型语言模型生成特定类型的输出.这个技术背后的原理是利用模型对输入的敏感性,通过提供特定格式或 ...

  9. WebGL实现简易的局部“马赛克”

    前言 接触过Canvas的小伙伴应该都知道,在Canvas2D中我们要加载一个图片很简单,通过调用drawImage API就能将图像绘制到画布上,当然在WebGL中我们也可以绘制图像,在绘制时我们需 ...

  10. Kafka源码分析(四) - Server端-请求处理框架

    系列文章目录 https://zhuanlan.zhihu.com/p/367683572 一. 总体结构 先给一张概览图: 服务端请求处理过程涉及到两个模块:kafka.network和kafka. ...