当前位置: 首页 > news >正文

Kubernetes ConfigMaps

文章目录

  • 简介
  • 创建ConfigMaps
    • 通过命令行使用字面值创建 ConfigMap。
    • 从文件创建ConfigMaps
    • 从多个文件创建 ConfigMap
    • 从目录创建 ConfigMap
    • 使用 YAML 创建 ConfigMap
  • 使用ConfigMaps
    • 使用 ConfigMaps作为环境变量
    • 使用 ConfigMap 作为卷挂载
    • 使用 ConfigMap 中的特定的key
  • ConfigMap 进阶用法
    • 合并 ConfigMap
    • 更新 ConfigMaps
    • 将 ConfigMaps 与Deployment结合使用
    • 环境特定的配置
    • 验证
    • 安全性
    • 使用描述性名称
    • 保持 ConfigMaps 简洁
    • 为 ConfigMaps 添加文档
  • 结论

简介

ConfigMap 是 Kubernetes 中的一种对象,用于以键值对的形式存储非机密的配置数据。ConfigMap 对于将配置设置与应用程序代码分离管理至关重要,这使得应用程序更加灵活和便于移植。
为什么使用 ConfigMap?

  • 将配置与代码解耦: 使用 ConfigMap,可以在不重新构建容器镜像的情况下更改配置设置。
  • 环境特定的配置: 轻松管理针对不同环境(开发、预生产、生产)的配置。
  • 集中化管理: 通过将配置集中存储在一个地方,简化配置管理。

创建ConfigMaps

通过命令行使用字面值创建 ConfigMap。

kubectl create configmap my-config --from-literal=db_host=database.example.com --from-literal=db_port=5432

从文件创建ConfigMaps

示例: app.properties

db_host=database.example.com
db_port=5432
log_level=DEBUG

从这个示例文件创建ConfigMap

kubectl create configmap my-config --from-file=app.properties

从多个文件创建 ConfigMap

kubectl create configmap my-config --from-file=app.properties --from-file=log.properties

从目录创建 ConfigMap

如果目录包含多个配置文件,则可以从整个目录创建 ConfigMap。

kubectl create configmap my-config --from-file=config-dir/

使用 YAML 创建 ConfigMap

可以在 YAML 文件中定义 ConfigMap,并使用 kubectl apply 创建它。
Example: configmap.yaml

apiVersion: v1
kind: ConfigMap
metadata:name: my-config
data:app.properties: |db_host=database.example.comdb_port=5432log_level: DEBUG

套用yaml文件

kubectl apply -f configmap.yaml

使用ConfigMaps

使用 ConfigMaps作为环境变量

apiVersion: v1
kind: Pod
metadata:name: my-pod
spec:containers:- name: my-containerimage: my-imageenvFrom:- configMapRef:name: my-config

使用 ConfigMap 作为卷挂载

ConfigMaps 也可以作为卷安装在 pod 中,允许容器直接访问配置文件。

apiVersion: v1
kind: Pod
metadata:name: my-pod
spec:containers:- name: my-containerimage: my-imagevolumeMounts:- name: config-volumemountPath: /etc/configvolumes:- name: config-volumeconfigMap:name: my-config

使用 ConfigMap 中的特定的key

如果只需要 ConfigMap 中的特定键,则可以明确指定它们。

apiVersion: v1
kind: Pod
metadata:name: my-pod
spec:containers:- name: my-containerimage: my-imageenv:- name: DB_HOSTvalueFrom:configMapKeyRef:name: my-configkey: db_host- name: DB_PORTvalueFrom:configMapKeyRef:name: my-configkey: db_port

示例:使用特定键作为卷

apiVersion: v1
kind: Pod
metadata:name: my-pod
spec:containers:- name: my-containerimage: my-imagevolumeMounts:- name: config-volumemountPath: /etc/config/db_hostsubPath: db_hostvolumes:- name: config-volumeconfigMap:name: my-configitems:- key: db_hostpath: db_host

ConfigMap 进阶用法

合并 ConfigMap

在某些情况下,可能需要为单个应用程序合并多个 ConfigMap。Kubernetes 允许在同一个 Pod 中使用多个 ConfigMap。
示例:将多个 ConfigMap 用作环境变量

apiVersion: v1
kind: Pod
metadata:name: my-pod
spec:containers:- name: my-containerimage: my-imageenvFrom:- configMapRef:name: my-config1- configMapRef:name: my-config2

更新 ConfigMaps

要更新 ConfigMap,可以使用 kubectl edit 直接编辑它。

kubectl edit configmap my-config

或者,您可以应用修改后的 YAML 文件中的更改。

kubectl apply -f updated-configmap.yaml

将 ConfigMaps 与Deployment结合使用

在生产环境中,通常会将 ConfigMaps 与 Kubernetes deployment结合使用。
示例:在部署中使用 ConfigMap

apiVersion: apps/v1
kind: Deployment
metadata:name: my-deployment
spec:replicas: 3selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-containerimage: my-imageenvFrom:- configMapRef:name: my-config

环境特定的配置

创建针对特定环境的 ConfigMap(例如,config-dev、config-prod),这样可以轻松管理不同环境的配置。

kubectl create configmap config-dev --from-file=dev.properties
kubectl create configmap config-prod --from-file=prod.properties

验证

验证 ConfigMap 的内容以避免应用程序出现错误。您可以使用诸如 kubeval 之类的工具来确保语法和结构的正确性。

kubeval configmap.yaml

安全性

虽然 ConfigMaps 不适合存储敏感数据,但应确保其访问权限仅限于必要的组件。使用基于角色的访问控制(RBAC)来控制访问权限。
示例: RBAC Policy

apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:namespace: defaultname: configmap-reader
rules:
- apiGroups: [""]resources: ["configmaps"]verbs: ["get", "list", "watch"]

这个配置允许角色持有者在 default 命名空间中读取(包括get、list、watch) ConfigMaps 的内容,但不能修改或删除它们。这通常用于对 ConfigMaps 的只读访问,比如配置管理或监控工具。

使用描述性名称

为 ConfigMaps 使用描述性名称,以便轻松识别其用途。

kubectl create configmap app-config --from-file=app.properties
kubectl create configmap log-config --from-file=log.properties

保持 ConfigMaps 简洁

避免在单个 ConfigMap 中放入过多数据。将大的配置拆分为多个 ConfigMaps 以便于管理

为 ConfigMaps 添加文档

在 YAML 文件中添加注释和文档,以描述每个键值对的用途和使用方式。

apiVersion: v1
kind: ConfigMap
metadata:name: my-config
data:# Database hostdb_host: database.example.com# Database portdb_port: "5432"

结论

ConfigMaps 是 Kubernetes 中用于分离配置数据的关键功能。通过合理使用 ConfigMaps,可以提升应用的灵活性和可维护性。遵循最佳实践,保持配置简洁、安全、有序,能有效管理和优化您的 Kubernetes 应用。

相关文章:

Kubernetes ConfigMaps

文章目录 简介创建ConfigMaps通过命令行使用字面值创建 ConfigMap。从文件创建ConfigMaps从多个文件创建 ConfigMap从目录创建 ConfigMap使用 YAML 创建 ConfigMap 使用ConfigMaps使用 ConfigMaps作为环境变量使用 ConfigMap 作为卷挂载使用 ConfigMap 中的特定的key ConfigMap…...

前端热门面试题目[一](HTML、CSS、Javascript、Node、Vue、React)

如何设计一个前端页面,实现PC端访问展示Web应用,移动端访问展示H5应用? 为了实现这一功能,通常需要使用响应式设计或者服务器端检测用户设备并返回相应的页面。以下是一些实现方法: 响应式设计:通过CSS媒…...

Swift 宏(Macro)入门趣谈(五)

概述 苹果在去年 WWDC 23 中就为 Swift 语言新增了“其利断金”的重要小伙伴 Swift 宏(Swift Macro)。为此,苹果特地用 2 段视频(入门和进阶)颇为隆重的介绍了它。 那么到底 Swift 宏是什么?有什么用&…...

ES6 Set、Map、WeakSet、WeakMap 四者辨析与实战应用详解

在 ES6 中,Set 和 Map 是两种非常重要的新增数据结构,它们都具有独特的特性和用途,能够帮助开发者更高效地处理和管理数据。除此之外,WeakSet 和 WeakMap 作为这两种数据结构的变种,也具有一些特殊的功能。下面我会从 Set 数据结构、Map 数据结构、WeakSet 和 WeakMap 对比…...

【数据结构】哈希表实现

前言 在本篇博客中,作者将会带领你使用C语言来实现一个哈希表。 一.什么是哈希表 在实现哈希表之前,我们先来学习一下什么是哈希表。 在传统的数据结构中,例如数组,链表和二叉平衡树等数据结构,这些数据结构的元素关键…...

Verilog的线与类型与实例化模块

1、线与类型 在Verilog中,线与(wire-AND)类型通常用于描述多个信号进行逻辑与(AND)操作的电路行为。虽然Verilog本身没有直接定义一种名为“线与”的数据类型,但可以通过使用wire类型结合特定的逻辑操作来…...

芯片测试-RF中的S参数,return loss, VSWR,反射系数,插入损耗,隔离度等

RF中的S参数,return loss, VSWR,反射系数,插入损耗,隔离度 💢S参数💢💢S11与return loss,VSWR,反射系数💢💢S21,插入损耗和增益&#…...

强化学习的几个主要方法(策略梯度、PPO、REINFORCE实现等)(上)

本笔记有大量参考蘑菇书EasyRL https://datawhalechina.github.io/easy-rl/#/ 包括其配图和部分文本。 1. 基本概念 1.1 基本流程 强化学习是一种学习框架,其中智能体(Agent) 通过与 环境(Environment) 的交互&#…...

Git远程仓库操作

文章目录 远程仓库连接Gitee克隆代码 多人协同问题说明 🏡作者主页:点击! 🤖Git专栏:点击! ⏰️创作时间:2024年12月1日13点10分 远程仓库 Git 是分布式版本控制系统,同一个 Git …...

GAGAvatar: Generalizable and Animatable Gaussian Head Avatar 学习笔记

1 Overall GAGAvatar(Generalizable and Animatable Gaussian Avatar),一种面向单张图片驱动的可动画化头部头像重建的方法,解决了现有方法在渲染效率和泛化能力上的局限。 旋转参数 现有方法的局限性: 基于NeRF的方…...

什么是VISUAL STUDIO CODE (V S CODE)

Visual Studio Code(简称VS Code)是由微软开发的一个免费的、开源的源代码编辑器。它是一个轻量级但功能强大的工具,支持多种编程语言和框架,广泛用于开发各种应用程序,尤其是Web开发。VS Code具备以下特点&#xff1a…...

2024年09月中国电子学会青少年软件编程(Python)等级考试试卷(三级)答案 + 解析

青少年软件编程(Python)等级考试试卷(三级) 分数:100 题数:38 一、单选题(共25题,共50分) 1. 以下表达式的值为True的是?( ) A. all( ,1,2,3) B. any([]) C. bool(abc) D. divmod(6,0)...

C++初阶——动态内存管理

目录 1、C/C内存区域划分 2、C动态内存管理:malloc/calloc/realloc/free 3、C动态内存管理:new/delete 3.1 new/delete内置类型 3.2 new/delete自定义类型 4、operator new与operator delete函数 5、new和delete的实现原理 5.1 内置类型 5.2 自定…...

如何查看阿里云ddos供给量

要查看阿里云上的 DDoS 攻击量,你可以通过阿里云的 云盾 DDoS 防护 服务来进行监控和查看攻击数据。阿里云提供了详细的流量监控、攻击日志以及攻击趋势分析工具,帮助用户实时了解 DDoS 攻击的情况。以下是九河云总结的查看 DDoS 攻击量的步骤&#xff1…...

MySQL中的事务隔离全详解

第一部分:MySQL事务的特性与并行事务引发的问题 1. 什么是事务及其四大特性(ACID)? 事务(Transaction)是数据库操作的基本单位,它将一组操作组合在一起,以确保这些操作作为一个整体…...

异常--C++

文章目录 一、异常的概念及使用1、异常的概念2、异常的抛出和捕获3、栈展开4、查找匹配的处理代码5、异常重新抛出6、异常安全问题7、异常规范 二、标准库的异常 一、异常的概念及使用 1、异常的概念 异常处理机制允许程序中独立开发的部分能够在运行时就出现的问题进行通信并…...

SeggisV1.0 遥感影像分割软件【源代码】讲解

在此基础上进行二次开发,开发自己的软件,例如:【1】无人机及个人私有影像识别【2】离线使用【3】变化监测模型集成【4】个人私有分割模型集成等等,不管是您用来个人学习还是公司研发需求,都相当合适,包您满…...

锁-读写锁-Swift

实现一 pthread_mutex_t: ReadWriteLock/Sources/ReadWriteLock at main SomeRandomiOSDev/ReadWriteLock GitHub https://swiftpackageindex.com/reers/reerkit/1.0.39/documentation/reerkit/readwritelock/ // // Copyright © 2022 reers. // // Pe…...

Kafka如何保证消息可靠?

大家好,我是锋哥。今天分享关于【Kafka如何保证消息可靠?】面试题。希望对大家有帮助; Kafka如何保证消息可靠? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Kafka通过多种机制来确保消息的可靠性,主要包…...

5.10【机器学习】

如果FLAG的画,就是已经有模型了,不然就新建一个模型,通过TORCH方法 在训练的时候,如果TRAIN的话就是训练,不然就是预测 forward前向预测出来一个结果,就是1234 在train方法里,进行多轮迭代&am…...

OpenClaw隐私计算:Qwen3.5-9B-AWQ-4bit本地处理加密图片

OpenClaw隐私计算:Qwen3.5-9B-AWQ-4bit本地处理加密图片 1. 为什么需要加密图片处理 去年我在帮一家小型金融机构做自动化流程优化时,遇到了一个棘手问题:他们需要AI自动分析客户上传的身份证和银行卡照片,但直接传输这些敏感图…...

JBoltAI Agent OS 管数字帮手的企业大管家

如果公司里每个人都有了智能体这个数字帮手,几十上百个帮手一起干活,没人管肯定乱套:有的可能乱翻公司数据,有的学会的好技能就自己用,管理者也不知道大家的数字帮手都在干些啥。而 JBoltAI Agent OS,就是管…...

Span<T>跨平台序列化加速,深度集成System.Text.Json与MessagePack(含Benchmark实测:吞吐量提升4.2倍)

第一章&#xff1a;Span<T>跨平台序列化加速&#xff0c;深度集成System.Text.Json与MessagePack&#xff08;含Benchmark实测&#xff1a;吞吐量提升4.2倍&#xff09;<T> 作为 .NET Core 2.1 引入的零分配内存视图类型&#xff0c;为高性能序列化提供了底层基石。…...

抖音下载神器:5分钟学会批量下载无水印视频的终极指南

抖音下载神器&#xff1a;5分钟学会批量下载无水印视频的终极指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback suppo…...

Docker+SyncTV+cpolar三件套:手把手教你搭建私人同步影院(附固定域名技巧)

DockerSyncTVcpolar三件套&#xff1a;打造高可用私人同步影院实战指南 在数字娱乐需求日益个性化的今天&#xff0c;私人影院的搭建已经从单纯的本地播放升级为兼具社交属性的协同体验。想象一下&#xff0c;无论好友身处何地&#xff0c;都能实时同步观看你精选的影片&#x…...

一键清理Windows驱动垃圾:DriverStore Explorer帮你释放20GB磁盘空间

一键清理Windows驱动垃圾&#xff1a;DriverStore Explorer帮你释放20GB磁盘空间 【免费下载链接】DriverStoreExplorer Driver Store Explorer 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer 你的Windows电脑是否越用越慢&#xff1f;C盘空间总是莫…...

财税合规数字化建设与税务师事务所行业实践

随着企业监管趋严与数字化不断深入&#xff0c;财税合规已成为企业经营管理中的重要环节。无论是中小企业还是集团公司&#xff0c;都需要建立规范的财务流程&#xff0c;完善纳税申报机制&#xff0c;强化风险自查能力&#xff0c;以实现合法合规&#xff0c;稳定经营。财税合…...

一网推百度爱采购代运营助力泰铖自动化斩获海量精准询盘

在工业制造数字化升级的当下&#xff0c;百度爱采购已然成为机械设备企业开拓线上客源的核心阵地&#xff0c;然而诸多中小厂商因缺乏专业运营手段&#xff0c;难以发挥平台价值。张家港市泰铖自动化设备有限公司主营半自动弯管机、缩管机、倒角机与切管机&#xff0c;曾面临线…...

GLM-. 全面支持与 Gemini CLI 集成:HagiCode 的多模型进化之路闲

1. 流图&#xff1a;数据的河流 如果把传统的堆叠面积图想象成一块块整齐堆叠的积木&#xff0c;那么流图就像一条蜿蜒流淌的河流&#xff0c;河道的宽窄变化自然流畅&#xff0c;波峰波谷过渡平滑。 它特别适合展示多个类别数据随时间的变化趋势&#xff0c;尤其是当你想强调…...

为什么92%的Python工程师还没掌握无锁并发?——CPython 3.13 subinterpreter实战避坑清单(含内存泄漏检测脚本)

第一章&#xff1a;无锁并发的底层逻辑与CPython 3.13 subinterpreter革命性意义无锁并发&#xff08;Lock-Free Concurrency&#xff09;并非简单地“不用锁”&#xff0c;而是通过原子操作&#xff08;如 compare-and-swap、load-acquire/store-release&#xff09;构建线程安…...