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: mysqllabels:app: mysql
data:master.cnf: | # 文件名,用| 表示下面的配置是有多行[mysqld]log-binlog_bin_trust_function_creators=1lower_case_table_names=1slave.cnf: |[mysqld]super-read-onlylog_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: mysqllabels: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: mysqlimage: busyboximagePullPolicy: IfNotPresentcommand: [ "/bin/sh", "-c", "sleep 3600" ]env:- name: log_bin   #定义环境变量log_binvalueFrom: 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: mysqlimage: busyboximagePullPolicy: IfNotPresentcommand: [ "/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: mysqllabels: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: mysqlimage: busyboximagePullPolicy: IfNotPresentcommand: [ "/bin/sh","-c","sleep 3600" ]volumeMounts:- name: mysql-configmountPath: /tmp/configvolumes:- name: mysql-configconfigMap: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秒)才能同步更新

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

零刻sei12 windows10 限制cpu最高频率,降低cpu功耗,调整风扇转速

为什么要降低cpu功耗 虽然风扇声音本身不大,但是我想在自习室用电脑,突然的风扇声音还是会影响到他人. 由于迷你主机集成度比较高不太可能换散热器,所以只能降低cpu功耗. 我的系统 版本 Windows 10 IoT 企业版 LTSC 版本号 21H2 安装日期 ‎2023/‎12/‎18 操作系统…

数据分析之Tebleau 的度量名称和度量值

度量名称 包含所有的维度 度量值 包含所有的度量 度量名称包含上面所有的维度&#xff0c;度量值包含上面所有的度量 当同时创建两个或两个以上度量或维度时&#xff0c;会自动创建度量名称和度量值 拖入省份为行(这会是还没有值的) 可以直接将销售金额拖到数值这里 或者将销售…

Android笔记(三十):PorterDuffXfermode实现旋转进度View

背景 核心原理是使用PorterDuffXfermode Path来绘制进度&#xff0c;并实现圆角 效果图 Android笔记(三十)效果演示 进度条绘制步骤 将ImageView矩形七个点的坐标存储起来&#xff08;configNodes&#xff09; 他们对应着7个不同的刻度&#xff0c;每个刻度的值 i * &#…

JAVAEE之网络编程

1.网络编程 网络编程&#xff0c;指网络上的主机&#xff0c;通过不同的进程&#xff0c;以编程的方式实现网络通信&#xff08;或称为网络数据传输&#xff09;。 当然&#xff0c;我们只要满足进程不同就行&#xff1b; 所以即便是同一个主机&#xff0c;只要是不同进程&am…

【MATLAB源码-第173期】基于matlab的RS编码的2FSK通信系统误码率仿真,通过AWGN信道输出误码率曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 通信系统的基本框架 在现代通信系统中&#xff0c;数据的传输通常涉及四个基本步骤&#xff1a;源编码、信道编码、调制和传输。源编码主要负责压缩数据&#xff0c;减少传输的数据量。信道编码则通过添加冗余信息来提高传输…

扫雷(蓝桥杯)

题目描述 小明最近迷上了一款名为《扫雷》的游戏。其中有一个关卡的任务如下&#xff0c; 在一个二维平面上放置着 n 个炸雷&#xff0c;第 i 个炸雷 (xi , yi ,ri) 表示在坐标 (xi , yi) 处存在一个炸雷&#xff0c;它的爆炸范围是以半径为 ri 的一个圆。 为了顺利通过这片土…

HANA中的内存及磁盘使用统计

1. 引言 在实际使用中&#xff0c;通过HANA的admin控制台&#xff0c;确实可以得到很多重要的信息。但有的时候不如人愿&#xff0c;你需要提供相应的SQL语句得到具体的信息。 比如&#xff0c;我要得到所有的行表的内存及磁盘占用信息&#xff1b;我需要得到所有列表的内存及…

AiEditor AI富文本编辑器

AI 时代&#xff0c;AIGC 正在蓬勃发展。作为一家 CMS 厂商&#xff0c;我们也正在积极寻求下一代 CMS 的迭代方向&#xff0c;以适应即将到来的新时代。 CMS 的一个核心能力是对 C&#xff08;Content&#xff09; 的编辑能力&#xff0c;它是通过 "编辑器" 来体现的…

基于springboot实现房屋租赁系统项目【项目源码+论文说明】

基于springboot实现房屋租赁系统演示 摘要 社会的发展和科学技术的进步&#xff0c;互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大人民群众的喜爱&#xff0c;也逐渐进入了每个用户的使用。互联网具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本…

AWS创建IAM用户,以及通过IAM用户登录

基本概念&#xff1a; IAM Identity Center&#xff08;AWS SSO&#xff09; 跨账户访问&#xff1a;IAM Identity Center允许用户使用他们自己的单一登录凭证来访问多个AWS账户和应用程序。这意味着你可以拥有一个账户和密码&#xff0c;通过IAM Identity Center的用户门户&…

基于STM32的武警哨位联动报警系统设计,支持以太网和WIFI通信

1.功能 本文提出的武警报警信息系统终端&#xff0c;可实现报警和联动响应&#xff0c;支持以太网和WIFI两种通信模式&#xff0c;可实现移动哨位报警和固定哨位报警&#xff0c;语音和显示报警信息用户可自行定制。 本终端主要由STM32F103处理器模块和C8051F340处理器模块构…

路径规划——搜索算法详解(五):Dynamic A Star(D*)算法详解与Matlab代码

昨天休息了一天&#xff0c;今天继续学习搜索算法&#xff01;前几天已经分别介绍了Dijkstra算法、Floyd算法、RRT算法、A*算法&#xff0c;无独有偶&#xff0c;上述算法都只适用于静态环境下两点规划的场景&#xff0c;但是大部分场景是实时变化的&#xff0c;这对规划算法提…

【应用笔记】LAT1413+快速开关蓝牙导致设备无广播

1. 问题背景 客户使用 BlueNRG-345MC 开发了一个 BLE 外设&#xff0c;和手机连接。在测试中发现&#xff0c;手机连接上外设之后&#xff0c;不断地在手机上点击蓝牙的开关按钮&#xff0c;造成设备不断地断开、重连&#xff1b;少则几次&#xff0c;多则几十次。点击之后&am…

乐乐音乐鸿蒙版-支持krc歌词(动感歌词、翻译和音译歌词)

简介 乐乐音乐主要是基于HarmonyOS开发的音乐播放器&#xff0c;它支持lrc歌词和动感歌词(ksc歌词、krc歌词和hrc歌词等)、多种格式歌词转换器及制作动感歌词、翻译歌词和音译歌词。 开发环境 ArkTS、Stage模型、SDK3.1、 API 9 注&#xff1a;没试过在真机条件下调试。 功…

LLM大模型可视化-以nano-gpt为例

内容整理自&#xff1a;LLM 可视化 --- LLM Visualization (bbycroft.net)https://bbycroft.net/llm Introduction 介绍 Welcome to the walkthrough of the GPT large language model! Here well explore the model nano-gpt, with a mere 85,000 parameters. 欢迎来到 GPT 大…

什么是数据结构

一、什么是数据结构 1.数据结构研究计算机数据间的关系 2.包括数据的逻辑结构和储存结构及其操作 数据的逻辑结构&#xff1a;表示数据运算之间的抽象关系 按每个元素可能具有的直接前趋数和后继数将逻辑结构分为“线性结构”和“非线性结构”两大类 数据的储存结构&#…

【JavaSE】初识线程,线程与进程的区别

文章目录 ✍线程是什么&#xff1f;✍线程和进程的区别✍线程的创建1.继承 Thread 类2.实现Runnable接口3.匿名内部类4.匿名内部类创建 Runnable ⼦类对象5.lambda 表达式创建 Runnable ⼦类对象 ✍线程是什么&#xff1f; ⼀个线程就是⼀个 “执行流”. 每个线程之间都可以按…

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

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

Qt中QMutex和QMutexLocker

一.QMutex和QMutexLocker知识介绍 QMutex是Qt中的一个互斥锁&#xff0c;用于保护共享数据不被多个线程同时修改。 QMutexLocker是一个辅助类&#xff0c;它简化了对QMutex的锁定和解锁过程。 当创建一个QMutexLocker实例时&#xff0c;它会自动锁定关联的QMutex。当QMutexLoc…

汇编语言第四版-王爽第2章 寄存器

二进制左移四位&#xff0c;相当于四进制左移一位。 debug命令实操&#xff0c;win11不能启动&#xff0c;需要配置文件 Windows64位系统进入debug模式_window10系统64位怎么使用debugger-CSDN博客