K8S之Configmap的介绍和使用

Configmap

  • Configmap概述
    • Configmap的简介
    • Configmap能解决的问题
    • Configmap应用场景
    • 局限性
  • Configmap创建方法
    • 通过命令行直接创建
    • 通过文件创建
    • 指定目录创建
    • 编写Configmap资源清单Yaml文件
  • Configmap的使用案例
    • 通过环境变量引入:使用configMapKeyRef
    • 通过环境变量引入:使用envfrom
    • 把configmap做成volume,挂载到pod (最常用)
  • Configmap热更新——使用挂载的 Volume

Configmap概述

Configmap的简介

configmap是K8S中的资源对象,用于保存非机密性的配置信息,可以使用 “键-值对” (Key-Value Pair)的形式保存,也可通过文件的形式保存。

Configmap能解决的问题

在部署服务的时候,每个服务都有自己的配置文件,如果一台服务器上部署多个服务,那么这些配置都存在这个节点上,假如需要对服务器扩容,扩容之后还是需要部署多个服务并且还是要管理这些服务的配置;或者有一个服务出现问题,需要修改配置文件,每台物理节点上的配置都需要修改。
这种方式肯定满足不了线上大批量的配置变更要求。 所以,k8s中引入了Configmap资源对象,可以当成volume挂载到pod中,实现统一的配置管理。
在这里插入图片描述
使用Configmap:

  1. 它是k8s中的资源, 相当于配置文件,可以有一个或者多个Configmap;
  2. 当做成Volume,k8s pod启动之后,通过 volume 形式映射到容器内部指定目录上,容器中应用程序按照原有方式读取容器内特定目录上的配置文件。
  3. 在容器看来,配置文件就像是打包在容器内部特定目录,整个过程对应用没有任何侵入。

Configmap应用场景

  • K8S中引入了Configmap资源对象,可以当成volume挂载到pod中,实现统一的配置管理;
  • 存在多个服务共用配置的情况,使用configmap可以友好的进行配置共享
  • 使配置信息和Docker镜像解耦,实现镜像的可移植性和可复用性;

局限性

ConfigMap在设计上不适用于保存大量数据的。在ConfigMap中保存的数据不可超过1 MiB。如果需要保存超出此限制的数据,可以考虑挂载其他的存储卷或者使用独立的数据库、文件服务。

Configmap创建方法

通过命令行直接创建

直接在命令行中指定configmap参数创建,通过 –from-literal 指定参数

例如:创建一个configmap,名叫:tomcat-config。
包含2个配置信息:tomcat_port=8080,server_name=myapp.tomcat.com
命令如下:

kubectl create configmap tomcat-config --from-literal=tomcat_port=8080 --from-literal=server_name=myapp.tomcat.com

查看已创建的configmap(ps. configmap 可简写为 cm)

kubectl describe cm tomcat-config

在这里插入图片描述

kubectl get cm

2:表示里面有2个配置
在这里插入图片描述

通过文件创建

通过指定文件创建一个configmap,通过 –from-file=<文件> 指定文件

例如:创建一个 nginx.conf 文件,与名叫 “www-nginx” 的configmap绑定。

vim nginx.conf
server {
  server_name www.nginx.com;
  listen 80;
  root /home/nginx/www/
}

www-nginx中,定义一个key是www,值是nginx.conf中的配置内容

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

查看configmap

kubectl describe configmap www-nginx1

在这里插入图片描述

或者,直接已文件名“ nginx.conf ” 作为key,值是nginx.conf中的内容

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

查看configmap

kubectl describe configmap www-nginx2

在这里插入图片描述

指定目录创建

将目录下的文件分别作为配置信息
例如:
1、创建配置目录

mkdir test-mysql-config
cd test-mysql-config/

2、模拟写入第一个配置文件

vim my-server.cnf 

写入:server-id=1

3、模拟写入第二个配置文件

vim my-slave.cnf 

写入:server-id=2

4、指定目录创建configmap

kubectl create configmap mysql-config --from-file=/root/test-mysql-config/

查看configmap详细信息

kubectl describe cm mysql-config

在这里插入图片描述

编写Configmap资源清单Yaml文件

vim mysql-configmap.yaml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: mysql
  labels:
    app: mysql
data:
  master.cnf: | # 文件名,用| 表示下面的配置是有多行
    [mysqld]
    log-bin
    log_bin_trust_function_creators=1
    lower_case_table_names=1
  slave.cnf: |
    [mysqld]
    super-read-only
    log_bin_trust_function_creators=1
kubectl apply -f mysql-configmap.yaml
kubectl describe cm mysql

在这里插入图片描述

Configmap的使用案例

通过环境变量引入:使用configMapKeyRef

创建一个存储mysql配置的configmap

vim mysql-configmap.yaml
apiVersion: v1
kind: ConfigMap
metadata:
  name: mysql
  labels:
    app: mysql
data:
    log: "1"
kubectl apply -f mysql-configmap.yaml
kubectl get cm

在这里插入图片描述

创建pod,引用Configmap中的配置

vim mysql-pod.yaml
apiVersion: v1
kind: Pod
metadata:
  name: mysql-pod
spec:
  containers:
  - name: mysql
    image: busybox
    imagePullPolicy: IfNotPresent
    command: [ "/bin/sh", "-c", "sleep 3600" ]
    env:
    - name: log_bin   #定义环境变量log_bin
      valueFrom: 
        configMapKeyRef:
          name: mysql     #指定configmap的名字
          key: log # 指定configmap中的key, 将它的value赋值给环境变量log_bin

更新资源清单文件

kubectl apply -f mysql-pod.yaml
kubectl exec -it mysql-pod -c mysql -- /bin/sh
printenv 

在这里插入图片描述

通过环境变量引入:使用envfrom

vim mysql-pod-envfrom.yaml
apiVersion: v1
kind: Pod
metadata:
  name: mysql-pod-envfrom
spec:
  containers:
  - name: mysql
    image: busybox
    imagePullPolicy: IfNotPresent
    command: [ "/bin/sh", "-c", "sleep 3600" ]
    envFrom: 
    - configMapRef:
       name: mysql     #指定configmap的名字

更新资源清单文件

kubectl apply -f mysql-pod-envfrom.yaml
kubectl exec -it mysql-pod-envfrom -- /bin/sh
printenv

在这里插入图片描述

把configmap做成volume,挂载到pod (最常用)

vim mysql-configmap.yaml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: mysql
  labels:
    app: mysql
data:
    log: "1"
    lower: "1"
    my.cnf: |
      [mysqld]
      Welcome=sissie

更新资源清单文件

kubectl apply -f mysql-configmap.yaml
kubectl get cm mysql

在这里插入图片描述

vim mysql-pod-volume.yaml
apiVersion: v1
kind: Pod
metadata:
  name: mysql-pod-volume
spec:
  containers:
  - name: mysql
    image: busybox
    imagePullPolicy: IfNotPresent
    command: [ "/bin/sh","-c","sleep 3600" ]
    volumeMounts:
    - name: mysql-config
      mountPath: /tmp/config
  volumes:
  - name: mysql-config
    configMap:
      name: mysql

更新资源清单文件

kubectl apply -f mysql-pod-volume.yaml
kubectl exec -it mysql-pod-volume -c mysql -- /bin/sh
cd /tmp/config/
ls

在这里插入图片描述

printenv

看不到以上的配置

Configmap热更新——使用挂载的 Volume

kubectl edit configmap mysql

把logs: “1”变成log: “2”
在这里插入图片描述
保存退出
在这里插入图片描述

kubectl exec -it mysql-pod-volume -c mysql -- /bin/sh
cat /tmp/config/log 

在这里插入图片描述
发现log值变成了2,更新生效了

注意:
更新 ConfigMap 后:通过环境变量注入的,使用该 ConfigMap 挂载的 Env 不会同步更新

使用该 ConfigMap 挂载的 Volume 中的数据需要一段时间(实测大概10秒)才能同步更新

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/505692.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

工厂方法模式与抽象工厂模式的深度对比

​&#x1f308; 个人主页&#xff1a;danci_ &#x1f525; 系列专栏&#xff1a;《设计模式》 &#x1f4aa;&#x1f3fb; 制定明确可量化的目标&#xff0c;坚持默默的做事。 &#x1f680; 转载自&#xff1a;设计模式深度解析&#xff1a;工厂方法模式与抽象工厂模式的深…

张颂文|永远保持好奇心的人,是永远进步的人。

哈喽,你好啊,我是雷工! 今天看到了张颂文的一段演讲,提到了他因为好奇心而被改变的人生。 如果想把单一和枯燥的工作做的更好,张颂文的办法是像一个孩子一样保持好奇心,不停地提出一些有趣的问题。 在5年的导游经历中,对每次游览的地点都像初次游览般保持好奇心,正因为…

【C语言】【Leetcode】2437. 有效时间的数目

文章目录 题目思路一、枚举思路二、回溯 题目 链接: link 思路一、枚举 这题的可以简单的看成 h1 h2 : m1 m2 的情况&#xff0c;其中 h1 和 h2 有关&#xff0c; m1 和 m2 有关&#xff0c;数目不多可以直接暴力枚举解决 int countTime(char * time) {int countHour 0;i…

【JavaWeb】Day24.Web入门——SPringBootWeb入门

什么是SPring&#xff1f; 我们可以打开Spring的官网(Spring | Home)&#xff0c;去看一下Spring的简介&#xff1a;Spring makes Java simple。Spring的官方提供很多开源的项目&#xff0c;我们可以点击上面的projects&#xff0c;看到spring家族旗下的项目&#xff0c;按照流…

PLC的大脑和心脏——CPU及西门子S7-1200CPU分类、CPU型号及端子接线图示例

CPU不断地采集输入信号&#xff0c;执行用户程序&#xff0c;刷新系统的输出。 根据供电方式和输入/输出方式的不同&#xff0c;西门子S7-1200 CPU分为3类&#xff0c;如下图1。 图1 CPU的分类 第1对字母&#xff0c;表示CPU的供电方式&#xff0c;AC&#xff08;Alternating…

leetcode 不同路径

62. 不同路径 问题描述 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。 问总共有多少条不同的…

python_2

文章目录 题目一运行结果 题目二运行结果 题目一 代码如下&#xff1a; def merge():ls_0 input("输入一个列表(空格隔开)&#xff1a;").split()ls_1 []for i in ls_0:ls_1.append(i)ls_1.sort()if ls_0 ls_1:print("这是一个有序列表")else:print(&qu…

国内首个BEV感知全栈系列学习教程:课程总结

目录 前言零. 简述一、BEV感知算法介绍二、BEV感知算法基础模块讲解三、LiDAR和Camera融合的BEV感知算法四、基于环视Camera的BEV感知算法五、BEV感知算法实战总结 前言 自动驾驶之心推出的《国内首个BVE感知全栈系列学习教程》&#xff0c;链接。记录下个人学习笔记&#xff0…

系统慢查询的思考

系统慢查询的思考 在一个系统中发现慢查询的功能或很卡的现象。你是怎么思考的&#xff1f;从哪几个方面去思考&#xff1f;会用什么工具&#xff1f; 一个系统使用了几年后都可能会出现这样的问题。原因可能有以下几点。 数据量的增加。系统中平时的使用中数据量是有一个累…

cdr弧形线条怎么画 cdr弧形线条怎么复制 CoreIDRAW官版 CoreIDRAW2024 平面设计软件

弧形线条可以增加设计的美感和独特性&#xff0c;使其看起来更加优雅和精致&#xff0c;并且弧形线条可以使设计更加流畅&#xff0c;减少直角和生硬的转折&#xff0c;使其看起来更加自然。那在cdr软件中怎么绘制弧形线条呢&#xff1f;下面由我带大家一起来了解cdr弧形线条怎…

c++编程(1)——重载函数、引用

欢迎来到博主的专栏——c编程 博主ID&#xff1a; 代码小豪 文章目录 前言重载函数函数重载的规则函数重载的原理引用引用变量的权限问题 前言 c语言对于编写大型项目有所缺陷&#xff0c;比如最常出现的标识符不能重复的问题&#xff08;软件的代码量通常是数以万计的&#…

机器语言编写helloworld

kvmtool下载编译 git clone https://github.com/kvmtool/kvmtool.git 下载后进入到目录执行make即可。 补码 计算机怎么表示负数&#xff1f;以四位有符号数为例&#xff0c;使用高位作为符号位&#xff0c;最高位为0表示正数&#xff0c;为1表示负数&#xff0c;其余三位用…

基于SSM远程同步课堂系统

基于SSM远程同步课堂系统的设计与实现 摘要 在这样一个网络数据大爆炸的时代&#xff0c;人们获取知识、获取信息的通道非常的多元化&#xff0c;通过网络来实现数据信息的获取成为了现在非常常见的一种方式&#xff0c;而通过网络进行教学&#xff0c;在网络上进行远程的课堂…

【软考】数据流图的设计原则

目录 1. 数据守恒原则2. 守恒加工原则3. 外部实体与外部实体之间不存在数据流4. 外部实体与外部存储之间不存在数据流5. 数据存储与数据存储之间不存在数据流6. 父图与子图的平衡原则7. 数据流与加工有关&#xff0c;且必须经过加工8.例题8.1 例题1 1. 数据守恒原则 1.输入与输…

嵌入式linux学习之opencv交叉编译

1.下载opencv源码 OpenCV官方源码下载链接为https://opencv.org/releases/&#xff0c;选择3.4.16版本下载。放在ubuntu系统~/opencv文件夹中&#xff0c;解压缩&#xff0c;opencv文件夹中新建build和install文件夹用于存放编译文件和安装文件&#xff1a; 2. 安装编译工具…

ES的RestClient相关操作

ES的RestClient相关操作 Elasticsearch使用Java操作。 本文仅介绍CURD索引库和文档&#xff01;&#xff01;&#xff01; Elasticsearch基础&#xff1a;https://blog.csdn.net/weixin_46533577/article/details/137207222 Elasticsearch Clients官网&#xff1a;https://ww…

MD5 计算 (下一代加密辅助类, Win32, C++)

CCNGHelper.h #pragma once #include <string> #include <tchar.h> #include <windows.h> #include <bcrypt.h>#ifdef _UNICODE using _tstring std::wstring; #else using _tstring std::string; #endif// 下一代加密辅助类 // 客户端: Windows Vi…

Vue2(十二):Vuex环境搭建、Vuex工作原理、Vuex开发者工具、几个配置项、多组件共享数据、Vuex模块化

一、Vuex 1.概念 专门在Vue中实现集中式状态&#xff08;数据&#xff09;管理的一个Vue插件&#xff08;use引入&#xff09;&#xff0c;对vue应用中多个组件的共享状态进行集中式的管理&#xff08;读&#xff0f;写&#xff09;&#xff0c;也是一种组件间通信的方式&…

阿里云优惠券领取方法大公开,省钱不再是难事

阿里云作为国内领先的云计算服务提供商&#xff0c;为广大用户提供了丰富的云产品和解决方案。为了吸引用户上云&#xff0c;阿里云经常推出各种优惠活动&#xff0c;其中最受用户欢迎的就是阿里云优惠券。那么&#xff0c;阿里云优惠券究竟是什么呢&#xff1f;我们又该如何领…

代码随想录第25天|216.组合总和III 17.电话号码的字母组合

216.组合总和III 216. 组合总和 III - 力扣&#xff08;LeetCode&#xff09; 代码随想录 (programmercarl.com) 和组合问题有啥区别&#xff1f;回溯算法如何剪枝&#xff1f;| LeetCode&#xff1a;216.组合总和III_哔哩哔哩_bilibili 找出所有相加之和为 n 的 k 个数的组…