kubernetes的存储ConfigMap
kubernetes的存储ConfigMap
标签(空格分隔): kubernetes系列
- 一: kubernetes的存储ConfigMap
一:kubernetes的存储
1.1 configMap 描述信息
ConfigMap 功能在 Kubernetes1.2 版本中引入,许多应用程序会从配置文件、命令行参数或环境变量中读取配 置信息。ConfigMap API 给我们提供了向容器中注入配置信息的机制,ConfigMap 可以被用来保存单个属性,也 可以用来保存整个配置文件或者 JSON 二进制大对象
配置中心:
1.1.1 configmap 的创建
1. 使用目录创建 $ ls docs/user-guide/configmap/kubectl/ game.properties ui.properties $ cat docs/user-guide/configmap/kubectl/game.properties enemies=aliens lives=3 enemies.cheat=true enemies.cheat.level=noGoodRotten secret.code.passphrase=UUDDLRLRBABAS secret.code.allowed=true secret.code.lives=30 $ cat docs/user-guide/configmap/kubectl/ui.properties color.good=purple color.bad=yellow allow.textmode=true how.nice.to.look=fairlyNice $ kubectl create configmap game-config --from-file=docs/user-guide/configmap/kubectl
mkdir configmap/dir -p cd configmap/dir/ vim game.properties --- enemies=aliens lives=3 enemies.cheat=true enemies.cheat.level=noGoodRotten secret.code.passphrase=UUDDLRLRBABAS secret.code.allowed=true secret.code.lives=30 --- vim ui.properties --- color.good=purple color.bad=yellow allow.textmode=true how.nice.to.look=fairlyNice --- —from-file 指定在目录下的所有文件都会被用在 ConfigMap 里面创建一个键值对,键的名字就是文件名,值就 是文件的内容 kubectl create configmap game-config --from-file=../dir/ kubectl get cm game-config -o yaml kubectl describe cm game-config
1.1.2 使用文件创建
只要指定为一个文件就可以从单个文件中创建 ConfigMap kubectl create configmap game-config-2 --from-file=game.properties kubectl describe cm game-config-2 kubectl get configmaps game-config-2 -o yaml —from-file 这个参数可以使用多次,你可以使用两次分别指定上个实例中的那两个配置文件,效果就跟指定整个 目录是一样的
1.1.3 使用字面值创建
使用文字值创建,利用 —from-literal 参数传递配置信息,该参数可以使用多次,格式如下 kubectl create configmap special-config --from-literal=special.how=very --from-literal=special.type=charm kubectl get cm kubectl get cm special-config -o yaml
1.1.4 Pod 中使用 ConfigMap
使用 ConfigMap 来替代环境变量 apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm ---- ---- vim env.yaml apiVersion: v1 kind: ConfigMap metadata: name: env-config namespace: default data: log_level: INFO ----------- kubectl apply -f env.yaml
vim evnpod.yaml ------ apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: wangyanglinux/myapp:v1 command: [ "/bin/sh", "-c", "env" ] env: - name: SPECIAL_LEVEL_KEY valueFrom: configMapKeyRef: name: special-config key: special.how - name: SPECIAL_TYPE_KEY valueFrom: configMapKeyRef: name: special-config key: special.type envFrom: - configMapRef: name: env-config restartPolicy: Never --- kubectl apply -f evnpod.yaml
1.1.5 用 ConfigMap 设置命令行参数
vim pod1.yaml ---- apiVersion: v1 kind: ConfigMap metadata: name: special-config-1 namespace: default data: special.how: very special.type: charm --- kubectl apply -f pod1.yaml
vim pod2.yaml ---- apiVersion: v1 kind: Pod metadata: name: dapi-test-pod1 spec: containers: - name: test-container image: wangyanglinux/myapp:v1 command: [ "/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ] env: - name: SPECIAL_LEVEL_KEY valueFrom: configMapKeyRef: name: special-config-1 key: special.how - name: SPECIAL_TYPE_KEY valueFrom: configMapKeyRef: name: special-config-1 key: special.type restartPolicy: Never ---- kubectl apply -f pod2.yaml
1.1.6 通过数据卷插件使用ConfigMap
vim stoage1.yaml --- apiVersion: v1 kind: ConfigMap metadata: name: special-config-2 namespace: default data: special.how: very special.type: charm --- kubectl apply -f stoage1.yaml
在数据卷里面使用这个 ConfigMap,有不同的选项。最基本的就是将文件填入数据卷,在这个文件中,键就是文 件名,键值就是文件内容 vim pod3.yaml --- apiVersion: v1 kind: Pod metadata: name: dapi-test-pod4 spec: containers: - name: test-container image: wangyanglinux/myapp:v1 command: [ "/bin/sh", "-c", "sleep 600" ] volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: special-config-2 restartPolicy: Never --- kubectl apply -f pod3.yaml
1.1.7 ConfigMap 的热更新
vim log-cm.yaml --- apiVersion: v1 kind: ConfigMap metadata: name: log-config namespace: default data: log_level: INFO --- kubectl apply -f log-cm.yaml
vim pod4.yaml --- apiVersion: extensions/v1beta1 kind: Deployment metadata: name: my-nginx spec: replicas: 1 template: metadata: labels: run: my-nginx spec: containers: - name: my-nginx image: wangyanglinux/myapp:v1 ports: - containerPort: 80 volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: log-config --- kubectl apply -f pod4.yaml
修改 log_level 的值为 DEBUG 等待大概 10 秒钟时间,再次查看环境变量的值 将 log—level 改为DEBUG kubectl edit cm log_config --- log_level : DEBUG --- kubectl exec my-nginx-c484b98b4-tgblg -ti -- cat /etc/config/log_level
ConfigMap 更新后滚动更新 Pod 更新 ConfigMap 目前并不会触发相关 Pod 的滚动更新,可以通过修改 pod annotations 的方式强制触发滚动更新 这个例子里我们在 .spec.template.metadata.annotations 中添加 version/config ,每次通过修改 version/config 来触发滚动更新 !!! 更新 ConfigMap 后: 使用该 ConfigMap 挂载的 Env 不会同步更新 使用该 ConfigMap 挂载的 Volume 中的数据需要一段时间(实测大概10秒)才能同步更新 kubectl patch deployment my-nginx --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "20190411" }}}}}

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
点餐系统的部署,Java点餐系统部署到Linux服务器
经过前面几节的学习,我们在腾讯云Linux服务器上成功的安装了jdk8,mysql8,并且教会了大家如何配置ssl证书实现https,今天我们就来正式的部署点餐系统到linux服务器,这里以腾讯云服务器为例。 准备工作 1,linux服务器安装jdk8 2,linux服务器安装mysql8 3,申请ssl证书,配置https 4,要有一个备案的域名上面这几条我前面的章节和视频都有讲解过,大家翻下我的文章,或者去看下我的视频:《点餐系统,java后台+点餐小程序》上面的准备工作都做好以后,我们就来开始正式的部署工作了。 一,申请并下载ssl证书 这里以腾讯云为例,我们首先要登录自己的腾讯云服务器,然后进入ssl证书申请页。 然后选择免费的ssl证书,申请即可 给证书绑定域名,一个证书只能绑定一个顶级域名或者二级域名。 等待审核,证书申请成功后点击下载 下载解压后有下面几个,我们使用Tomcat把证书放到我们项目里的resources目录下 二,配置ssl证书到点餐项目里 把上图的配置代码贴出来给大家,一定要注意,根据代码上的注释来配置。 server: #https加密端口号 443 p...
- 下一篇
Docker安装mysql8
一、下载mysql8镜像 docker pull mysql 二、创建mysql8配置文件 vi /etc/my.cnf #编辑MySQL配置文件 my.cnf文件内容 # Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; version 2 of the License. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCH...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS关闭SELinux安全模块
- CentOS8安装Docker,最新的服务器搭配容器使用
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Windows10,CentOS7,CentOS8安装Nodejs环境
- 设置Eclipse缩进为4个空格,增强代码规范