写点什么

Kubernetes 1.2 新功能解析:ConfigMap (中)

  • 2020-03-13
  • 本文字数:2108 字

    阅读完需:约 7 分钟

Kubernetes 1.2 新功能解析:ConfigMap (中)

使用 ConfigMap

很多应用程序的配置需要通过配置文件,命令行参数和环境变量的组合配置来完成。这些配置应该从 image 内容中解耦,以此来保持容器化应用程序的便携性。ConfigMap API 资源提供了将配置数据注入容器的方式,同时保持容器是不知道 Kubernetes 的。ConfigMap 可以被用来保存单个属性,也可以用来保存整个配置文件或者 JSON 二进制大对象。

ConfigMap 总览

ConfigMap API 资源保持键-值对配置数据,这个数据可以在 pods 里使用,或者被用来为像 controller 一样的系统组件存储配置数据。虽然 ConfigMap 跟 Secrets 类似,但是 configmap 可以更方便的处理不包含敏感信息的字符串


让我们来看看完成的例子吧:



data 一栏包括了配置数据。就如同你们看到的那样,ConfigMap 可以被用来保存单个属性,也可以用来保存一个配置文件。


配置数据可以通过很多种方式在 Pods 里被使用。ConfigMaps 可以被用来:


1、设置环境变量的值


2、在容器里设置命令行参数


3、在数据卷里面创建 config 文件


用户和系统组件两者都可以在 ConfigMap 里面存储配置数据。

创建 ConfigMaps

你可以使用 kubectl create configmap 命令轻松从文字值、文件或者目录来创建 ConfigMaps。


让我们来看一看创建 ConfigMap 的很多不同的方法吧:

从目录创建

现在我们已经有一个包含一些文件的目录,它已经包含了我们想要设置 ConfigMaps 的数据:



kubectl create configmap 命令可以被用来创建 ConfigMap 来存储这个目录里面每个文件的内容:



当–from-file 指向目录的时候,每个在目录底下的所有文件会被用在 ConfigMap 里面创建一个键值对,键的名字就是文件名,值就是文件的内容。


让我们来看一下这个命令创建的 ConfigMap:



你可以看到在映射里面的两个是从 kubectl 指定的目录中创建的文件名。这些键的内容可能会很大,所以在 kubectl describe 的输出中,你只能够看到键的名字和他们的大小。


如果我们想要看到键的值的话,我们可以仅仅只是 kubectl get 资源:


从文件创建

我们也可以传递给–from-file 一个特定文件,并且多次传递到 kubectl。以下命令跟上文例子中的结果是一样的:



我们也可以用 --from-file 通过传递 key=value 为个别文件设置键来使用:


--from-file=game-special-key=docs/user-guide/configmap/kubectl/game.properties 
复制代码



从字面值创建

为 ConfigMap 使用 kubectl create configmap 提供字面值。–from-literal 选项采用了 语法,这个语法允许字面值被直接运用到命令行:


在 pods 里面使用 ConfigMap

使用案例:在环境变量中使用 ConfigMap


ConfigMap 可以被用来填入环境变量。举个例子,思考以下的 ConfigMap:



我们可以像这样在一个 pod 中来使用这个 ConfigMap 的键:



当这个 pod 运行的时候,它的输出将包括以下几行:


使用案例:用 ConfigMap 设置命令行参数

ConfigMap 也可以被使用来设置容器中的命令或者参数值。这是一个已经完成的使用 Kubernetes$(VAR_NAME)替换的语法。考虑 ConfigMap:



为了输入值到命令行里面,我们必须使用我们想要使用的键来作为环境变量,就如在上一个例子中的一样。然后我们可以参考他们,在容器的命令里使用 $(VAR_NAME)语法。



当这个 pod 正在运行的时候,从 test-container 容器的输出将会是:


使用案例:通过数据卷插件使用 ConfigMap

ConfigMap 也可以在数据卷里面被使用。再次回到我们的 ConfigMap 的例子:



在数据卷里面使用这个 ConfigMap,我们有不同的选项。最基本的就是将文件填入数据卷,在这个文件中,键就是文件名,键值就是文件内容:



当这个 pod 运行的时候,输出是这样的:



我们也可以在 ConfigMap 值被映射的数据卷里控制路径。



当 pod 运行的时候,输出是这样的:


真实案例:配置 Redis

让我们来看一下真实的案例:用 Configmap 配置 redis。我们想要将 redis 作为一个缓存用推荐配置来输入 redis。Redis 配置应该包括:



docs/user-guide/configmap/redis 里面有这样一个文件;有了它,我们可以使用下面的命令来创建一个 ConfigMap 实例:




现在,让我们用这个配置来创建一个 pod:



注意,这个 pod 有一个 ConfigMap 数据卷,它在一个叫 redis.conf 的文件里替代了 example-redis-config ConfigMap 的 redis-config 密钥。这个数据卷增长到 redis 容器的 /redis-master 目录里,在/redis-master/redis.conf 里替代了我们的配置文件,/redis-master/redis.conf


就是 image 为 master 查找的 redis 配置文件。



如果我们 kubectl exec 到这个 pod,并且运行 redis-cli 工具,我们可以检查到我们的配置被正确运用:


限制条件

ConfigMaps 必须在 pod 中被使用之前创建。Controllers 可以会被写来容忍某些配置文件数据的缺失。Configmaps 属于 namespace。他们只有在相同的 namespaces 中通过 pods 被引用。


ConfigMap 大小的配额是已经一个设置好的功能。


Kubelet 只支持从 API 服务器的 pods 使用 ConfigMap。这包括了任意的用 Kubectl 创建的 pods,或者间接的通过 replication controller 创建的 pods。它不包括通过 Kubelet 的 --manifest-url 标志创建的 pods,也不包括从它的 REST API 创建的 pods(一般不用这些方法创建 pods)。


本文转载自才云 Caicloud 公众号。


原文链接:https://mp.weixin.qq.com/s/qBL9P6LkU4_ko_o33IuqZg


2020-03-13 17:25726

评论

发布
暂无评论
发现更多内容

鸟枪换炮,利用python3对球员做大数据降维(因子分析得分),为C罗找到合格僚机

刘悦的技术博客

Python 数据分析 特征选择 降维

IPFS挖矿矿机系统开发方案丨IPFS挖矿矿机源码案例

系统开发咨询1357O98O718

IPFS云算力挖矿系统开发 IPFS算力挖矿系统开发搭建

5G与4G的差别及应用

anyRTC开发者

人工智能 android AI 5G WebRTC

测开之函数进阶· 第6篇《闭包》

清菡软件测试

测试开发

Java多线程编程核心技术

田维常

多线程

SpringCloudGateway(一) 概览

Java SpringcloudGateway

智慧社区综合应用平台搭建,社区管理解决方案

t13823115967

智慧社区管理平台开发 智慧平安社区平台建设

CKLC挖矿矿机系统开发案例介绍

系统开发咨询1357O98O718

CKLC挖矿矿机系统软件开发 CKLC挖矿矿机系统开发 CKLC挖矿矿机APP系统开发

技术干货 | 六分钟学会使用 HBuilder 引入构建 mPaaS 小程序

蚂蚁集团移动开发平台 mPaaS

小程序 uni-app mPaaS

10次面试,2份offer —— 大龄程序员 2020 求职记录

escray

面试 架构师训练营第 1 期

公安警务报警系统,二维码一键定位报警

t13823115967

二维码定位报警系统开发 微警务 二维码定位

爆赞!P8架构师总结29篇多线程与高并发+设计模式核心笔记

Java架构追梦

Java 学习 架构 面试 多线程高并发

通达同城快递设计方案

garlic

架构师训练营第 1 期

送你一份迷你书,全面了解如何做好大促技术备战

京东科技开发者

DevOps

LeetCode题解:239. 滑动窗口最大值,二叉堆,JavaScript,详细注释

Lee Chen

算法 大前端 LeetCode

令数字起舞,让自然微笑:TECH4ALL的2020启示录

脑极体

盘点2020 | YourBatman 2020年感悟关键词:科比、裁员、管理层、活着

YourBatman

裁员 盘点2020 科比 管理层 活着

母鸡下蛋实例:多线程通信生产者和消费者wait/notify和condition/await/signal条件队列

叫练

多线程与高并发 Wait lock 线程互斥 await

IPFS云算力挖矿系统开发详解案例及源码

系统开发咨询1357O98O718

云算力挖矿系统开发详解 云算力APP系统软件开发 云算力模式系统开发源码 云算力软件系统开发定制

AAAI 2021论文:利用深度元学习对城市销量进行预测(附论文下载)

京东科技开发者

数据库 大数据 时序预测

跨年巨作!13万字!腾讯高工纯手写“JDK源码笔记”直接带你飙向实战

比伯

Java 编程 架构 面试 计算机

MySQL为Null会导致5个问题,个个致命!

王磊

MySQL MySQL使用

阿里面试:Mybatis中方法和SQL是怎么关联起来的呢?

田维常

mybatis

分享一个普通程序员的“沪漂”六年的历程以及感想

程序员老猫

回忆录 经历 年终总结 沪漂 上海买房

IPFS分布式存储矿机系统APP软件开发

系统开发

RPC Demo(二) 基于 Zookeeper 的服务发现

Java zookeeper RPC 服务发现

架构师训练营第一周作业

Mark

NoahTenet诺亚信条软件系统APP开发

系统开发

Spring cloud Gateway(二) 一个Http请求的流程解析

Java 网关

IPFS挖矿系统开发详情案例

系统开发咨询1357O98O718

IPFS云算力挖矿系统开发 IPFS算力挖矿软件系统开发

为了搞清楚类加载,竟然手撸JVM!

小傅哥

JVM 小傅哥 类加载 生命周期 加载机制

Kubernetes 1.2 新功能解析:ConfigMap (中)_语言 & 开发_才云科技_InfoQ精选文章