一、StorageClass

  在前一篇文章中,手动定义了pv,并让pvc关联至pv;现实中在pvc申请存储空间时,未必就有现成的pv符合pvc申请的需求,该怎么办呢?

Kubernetes提供了描述存储的方法(StorageClass)。比如,在存储系统中划分一个1TB的存储空间提供给Kubernetes使用,当用户需要一个10G的PVC时,会立即通过restful发送请求,从而让存储空间创建一个10G的image,之后在我们的集群中定义成10G的PV提供给当前的PVC作为挂载使用。在此之前我们的存储系统必须支持restful接口,比如ceph分布式存储,而glusterfs则需要借助第三方接口完成这样的请求。  

二、Secret和configMap

    configMap和secret是特殊类型的存储卷,它们不是提供pod存储空间,而是给管理员或用户提供从集群外部向Pod内部的应用注入配置信息的方式。

其实ConfigMap功能在Kubernetes1.2版本的时候就有了,许多应用程序会从配置文件、命令行参数或环境变量中读取配置信息。这些配置信息需要与docker image解耦,你总不能每修改一个配置就重做一个image吧?ConfigMap API给我们提供了向容器中注入配置信息的机制,ConfigMap可以被用来保存单个属性,也可以用来保存整个配置文件或者JSON二进制大对象。

Secret解决了密码、token、密钥等敏感数据的配置问题,而不需要把这些敏感数据暴露到镜像或者Pod Spec中。Secret可以以Volume或者环境变量的方式使用。
Secret有三种类型:

  • Service Account :用来访问Kubernetes API,由Kubernetes自动创建,并且会自动挂载到Pod的/run/secrets/kubernetes.io/serviceaccount目录中;
  • Opaque :base64编码格式的Secret,用来存储密码、密钥等;
  • kubernetes.io/dockerconfigjson :用来存储私有docker registry的认证信息;

查看资源定义清单字段

    [root@master ~]# kubectl explain pods.spec.volumes

  [root@master ~]# kubectl explain cm          #cm:ConfigMap

   [root@master ~]# kubectl create configmap --help     #可以直接在命令行创建一个configmap  

  1、configmap

  (1)创建configmap

  configmap可以在命令行创建,也可以用文件生成;

  a、在命令行手动创建一个configmap

[root@master ~]# kubectl create configmap nginx-config --from-literal=nginx_port=80 --from-literal=server_name=myapp.mageedu.com

  #nginx-config:名字; --from-literal:用来定义一对键值

  [root@master ~]# kubectl get cm

  

  [root@master ~]# kubectl describe cm nginx-config

  

  b、用文件生成configmap

  准备配置文件;

  "myapp.magedu.com"后面应该有一个";",我这里忘记写了,需要写上;

  

  创建:

  [root@master configmap]# kubectl create configmap nginx-www --from-file=./www.conf  #此时不指定键,文件名当键,文件内容当值;

  

  (2)创建pod,并挂载configmap(环境变量方式注入到pod)

  [root@master configmap]# vim pod-configmap.yaml

  

  [root@master configmap]# kubectl apply -f pod-configmap.yaml

  

  查看变量是否被注入到容器中:

  [root@master configmap]# kubectl exec -it pod-cm-1 -- /bin/sh

  

  发现环境变量已被注入到容器中;这种只在容器启动时生效一次,如果后续改了configmap,也不会再次生效,只有再次启动才行;

  下面,修改一下configmap:

  [root@master configmap]# kubectl edit cm nginx-config

  

  再次查看容器变量:

  

  (3)存储卷方式挂载configmap

  Volume 形式的 ConfigMap ,支持动态更新;

  我上面创建了两个configmap:

    nginx-config      #是在命令行创建的,不是以文件的形式

    nginx-www         #是以文件的形式创建的

  a、挂载nginx-config

  [root@master configmap]# vim pod-configmap-2.yaml

  

  [root@master configmap]# kubectl apply -f pod-configmap-2.yaml

  

  查看挂载,此时端口是8080:

  

  然后我们修改一下端口,测试一下配置文件的动态更新:

  [root@master ~]# kubectl edit cm nginx-config    #将端口改为8088

  

  再次查看,发现端口已经动态更新了:

  

  b、挂载nginx-www

  [root@master configmap]# vim pod-configmap-3.yaml

  

  

  [root@master configmap]# kubectl exec -it pod-cm-3 -- /bin/sh

  

  然后定义一个html文件:

  

  在node02中测试访问:

  

  

  然后改一下configmap里定义的端口,测试一下配置文件的动态更新:

  [root@master ~]# kubectl edit cm nginx-www

  

  稍等片刻,再次查看,nginx容器中的配置文件已经自动更新:

  

  但是此时nginx仍然监听的是80端口,我们需要手动重载一下配置文件:

  

  在node02中再次访问:

  

  2、Secret

  [root@master ~]# kubectl create secret --help

   Available Commands:
     docker-registry   创建一个给 Docker registry 使用的 secret
     generic   从本地 file, directory 或者 literal value 创建一个 secret
     tls   创建一个 TLS secret

  Usage:

    kubectl create secret [flags] [options]

  [root@master ~]# kubectl create secret generic --help

  Usage:

    kubectl create secret generic NAME [--type=string] [--from-file=[key=]source] [--from-literal=key1=value1]

  (1)在命令行创建secret

  [root@master configmap]# kubectl create secret generic mysql-root-password --from-literal=passwprd=Myp@ss123

  

  

  此种加密使用的base64,意义不大;

  (2)挂载secret(环境变量方式注入到pod)

  [root@master configmap]# vim pod-secret-1.yaml

  

  [root@master configmap]# kubectl apply -f pod-secret-1.yaml

  

  查看变量是否注入:

  

  (3)存储卷方式挂载secret

  此方式与configmap类似;

k8s-存储卷2-configMap-Secret-十三的更多相关文章

  1. k8s存储卷概述

    pod本身具有生命周期,故其内部运行的容器及其相关数据自身均无法持久存在.docker支持配置容器使用存储卷将数据持久存储于容器自身文件系统之外的存储空间中,它们可以是节点文件系统或网络文件系统之上的 ...

  2. K8s存储卷、pv和pvc的使用

    emptyDIR 临时目录 hostPath :使用主机的路径 网络存储: 传统的设备存储:NAS,SAN 分布式存储:glusterfs,rbd,cephfs 云存储:EBS,Azure,阿里云的 ...

  3. kubernetes系列12—二个特色的存储卷configmap和secret

    本文收录在容器技术学习系列文章总目录 1.configmap 1.1 认识configmap ConfigMap用于保存配置数据的键值对,可以用来保存单个属性,也可以用来保存配置文件.ConfigMa ...

  4. 09-kubernetes configMap secret

    目录 配置容器化应用配置的方式 命令创建和测试configMap 创建一个Pod 挂在测试 命令行文件类创建方式 创建Pod测试 创建后测试 贴近实际进行测试 创建后测试 secret 举例测试 ge ...

  5. k8s系列---存储卷pv/pvc。configMap/secert

    因为pod是有生命周期的,pod一重启,里面的数据就没了.所以我们需要数据持久化存储. 在k8s中,存储卷不属于容器,而是属于pod.也就是说同一个pod中的容器可以共享一个存储卷. 存储卷可以是宿主 ...

  6. k8s学习笔记之八:存储卷

    第一章.前言 默认情况下容器的数据都是非持久化的, 在容器消亡以后数据也跟着丢失, 所以 Docker 提供了 Volume 机制以便将数据持久化存储. 类似的, Kubernetes 提供了更强大的 ...

  7. k8s volume存储卷(四)

    介绍 volume存储卷是Pod中能够被多个容器访问的共享目录,kubernetes的volume概念,用途和目的与docker的volume比较类似,但两者不能等价,首先,kubernetes中的v ...

  8. k8s配置中心-configmap,Secret密码

    目录 k8s配置中心-configmap,Secret 创建ConfigMap 使用ConfigMap subPath参数 Secret 官方文档 编写secret清单 使用secret 在 Pod ...

  9. k8s volume存储卷

    k8s volume存储卷   介绍 volume存储卷是Pod中能够被多个容器访问的共享目录,kubernetes的volume概念,用途和目的与docker的volume比较类似,但两者不能等价, ...

  10. k8s之存储卷及pvc

    1.存储卷概述 因为pod是有生命周期的,pod一重启,里面的数据就没了,所以我们需要数据持久化存储,在k8s中,存储卷不属于容器,而是属于pod,也就是说同一个pod中的容器可以共享一个存储卷,存储 ...

随机推荐

  1. C#-訪问轰炸机,新建进程,结束进程...(ConsoleApp)---ShinePans

    这个程序能够自己主动打开要打开的网址,而且自己主动结束进程,这样能够达到博文点击流量的添加 program.cs using System; using System.Collections.Gene ...

  2. BUPT复试专题—哈夫曼编码(2009)

    题目描述 哈夫曼编码中  平均码长=码长×码字出现的概率 如:ABCDE 五个字符的出现次数分别为50 20 5 10 15 那么,其哈夫曼编码为A:0   B:10   C:1110   D:111 ...

  3. IDEA中Thrift插件配置

    方法一:直接在IDEA界面中配置 打开IDEA的插件中心,搜索 Thrift 即可安装 方法二:手动下载Thrift插件安装 有时像在IDEA中安装Lombok插件一样,有时由于网络原因,方法一不奏效 ...

  4. 简单使用 Mvc 内置的 Ioc

    简单使用 Mvc 内置的 Ioc 本文基于 .NET Core 2.0. 鉴于网上的文章理论较多,鄙人不才,想整理一份 Hello World(Demo)版的文章. 目录 场景一:简单类的使用 场景二 ...

  5. uboot 对 FAT 分区的解析

    uboot 对 FAT 分区的解析 改写 UBOOT 从 U 盘读入固件,然后刷机.发现有的 U 盘无法正确读到分区,跟踪了一下发现自己写的代码有漏洞,只尝试解析分区表里的第一个分区.跟踪的过程中重温 ...

  6. iOS 内购遇到的坑

    一.内购沙盒测试账号在支付成功后,再次购买相同 ID 的物品,会提示如下内容的弹窗.您以购买过此APP内购项目,此项目将免费恢复 原因: 当使用内购购买过商品后没有把这个交易事件关,所以当我们再次去购 ...

  7. ECMAScript学习笔记

    1. ECMAScript不存在块级作用域,因此在循环内部定义的变量,在循环外也是可以访问的 eg: var count =10; fpr(var i=0; i<count; i++){ ale ...

  8. java序员必备的十大技能

    想成为一名出色的Java程序员么?本文将为大家重点介绍程序员必备的十大技能,成就您的梦想.       1.语法:必须比较熟悉,在写代码的时候IDE的编辑器对某一行报错应该能够根据报错信息知道是什么样 ...

  9. __sizeof__()

    https://bugs.python.org/issue2898 https://bugs.python.org/file10353/footprint.patch Index: Python/sy ...

  10. C++,Base64编解码字符串或文件

    参考链接:在C语言中使用libb64进行Base64编解码 GitHub地址:https://github.com/BuYishi/cpp_base64_demo base64_demo.cpp #i ...