AICon 上海站|90%日程已就绪,解锁Al未来! 了解详情
写点什么

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:25705

评论

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

社交泛娱乐之外,融云 IM 在商业沟通中的实践

融云 RongCloud

IM 泛娱乐 通讯

深度剖析React懒加载原理

xiaofeng

前端 React

自建MQTT迁移IoT物联网平台实战——实践类

阿里云AIoT

监控 物联网 消息中间件 数据格式 网络性能优化

深度探讨react-hooks实现原理

xiaofeng

前端 React

美团前端二面常考react面试题及答案

xiaofeng

前端 React

设备端资源包文件(人脸库,音频库,图片资源等)更新方案——实践类

阿里云AIoT

阿里云 物联网 IoT 对象存储

详细解读 React useCallback & useMemo

夏天的味道123

前端 React

经常被问到的react-router实现原理详解

夏天的味道123

前端 React

软件测试 | UI自动化中的分层设计

测吧(北京)科技有限公司

测试

DataEase 集成 CAS 实现用户单点登录

搞大屏的小北

CAS SSO 单点登录 BI 分析工具 DataEase

软件测试 | 普罗米修斯 - 初识PromQL

测吧(北京)科技有限公司

测试

软件测试 | 普罗米修斯 - PromQL进阶

测吧(北京)科技有限公司

测试

模块7 王者荣耀商城-异地多活架构

KING

软件测试 | UI自动化设计军规

测吧(北京)科技有限公司

测试

软件测试/测试开发 | 想测试入门就必须要懂的软件开发流程

测试人

软件测试 自动化测试 测试发开

【网易云商】概念解读稳定性保障

网易云信

稳定性 稳定性测试

软件测试 | UI自动化常用设计模式

测吧(北京)科技有限公司

测试

软件测试 | UI自动化常用设计模式(二)

测吧(北京)科技有限公司

测试

灾备是什么意思?怎么简单理解?

行云管家

灾备

容器化部署是什么意思?有什么优势?

行云管家

容器化

百度百舸 · AI 异构计算平台,加速自动驾驶模型迭代

百度开发者中心

人工智能 自动驾驶 计算 AIIaaS

美团前端二面经典react面试题总结

夏天的味道123

前端 React

EMQ广州Office正式启用|在新一站续写开源

EMQ映云科技

开源 物联网 IoT emq 企业号 3 月 PK 榜

低代码如何推动自动化未来

力软低代码开发平台

【干货】Maya学习过程中遇到的困难和解决方法

Finovy Cloud

物联网平台企业版:设备接入实例节点开发实战——实践类

阿里云AIoT

监控 前端开发 物联网 数据处理 网络性能优化

前端一面react面试题指南

xiaofeng

前端 React

滴滴前端二面常考react面试题(持续更新中)

夏天的味道123

前端 React

海泰方圆精彩亮相第六届中国人工智能与大数据海南高峰论坛

电子信息发烧客

联合 NVIDIA 完成首批 17 个自动驾驶模型优化

百度开发者中心

人工智能 自动驾驶

你有“ChatGPT综合征”吗:想搞钱,或是失业焦虑?

引迈信息

人工智能 AI ChatGPT

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