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-stream-9 centos9 配置国内yum源 阿里云源

    源配置 tips: yum配置文件路径 /etc/yum.repos.d/centos.repo 1.备份源配置 [Very Important!] mv /etc/yum.repos.d/cento ...

  2. c# 解决死锁问题Monitor

    前言 在高并发中,一个很关键的问题就是要避免死锁. 那么为什么会产生死锁呢?这种情况多见吗? 举一个例子: 比如方法一中先lock(object1),在lock(object1)中lock(objec ...

  3. VulnHub-Jangow-01-1.0.1打靶记录

    知识点 NMAP参数 -sV 获取系统信息 -sT TCP扫描可能会留下日志记录 -sC 使用默认脚本(在-A模式下不需要) -p1-xxx 扫描端口号 -p- ==>等价于 -p1-65535 ...

  4. kubernetes CNI(Container Network Inferface)

    为什么需要 CNI 在 kubernetes 中,pod 的网络是使用 network namespace 隔离的,但是我们有时又需要互相访问网络,这就需要一个网络插件来实现 pod 之间的网络通信. ...

  5. nethttp和gin 路由

    net/http 路由注册 func test1() { http.HandleFunc("/", func(w http.ResponseWriter, r *http.Requ ...

  6. 剑指offer56(Java)-数组中出现的次数Ⅰ(中等)

    题目: 一个整型数组 nums 里除两个数字之外,其他数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度是O(n),空间复杂度是O(1). 示例 1: 输入:nums = [4,1, ...

  7. 通过Jenkins构建CI/CD实现全链路灰度

    简介: 本文介绍通过 Jenkins 构建流水线的方式实现全链路灰度功能. 作者:卜比   本文介绍通过 Jenkins 构建流水线的方式实现全链路灰度功能. 在发布过程中,为了整体稳定性,我们总是希 ...

  8. 持续定义Saas模式云数据仓库+BI

    云数据仓库概述 今天和大家一起探讨一下我们Saas模式下云数据仓库加上商业智能BI能有什么新的东西出来.我们先来看一下云数据仓库的一些概述.预测到2025年, 全球数据增长至175ZB, 中国数据量增 ...

  9. [GPT] 怎么查看我的 macbook 有多少显存

      您可以按照以下步骤查看您MacBook的显存大小: 点击屏幕左上角的苹果图标,选择"关于本机". 在弹出的窗口中,点击"系统报告". 在左侧栏中选择&quo ...

  10. GitHub 的 Action 判断仅在主仓库才执行脚本

    我有一个 GitHub 项目,这个项目配置了仅需要在源仓库才能执行的 Action 如推送 NuGet 等发布动作.如何在 Action 里面设置让 Fork 的仓库不执行 Action 的步骤 想要 ...