深入浅出 Kubernetes:初识 Pod(下)
深入浅出 Kubernetes:初识 Pod(下)
一 Projected Volume
作为 Kubernetes 比较核心的编排对象,Pod 携带的信息极其丰富。在 Kubernetes 中,有几种特殊的 Volume,它们存在的意义不是为了存放容器里的数据,也不是用来进行容器和宿主机之间的数据交换。这些特殊 Volume 的作用,是为容器提供预先定义好的数据。从容器的角度来看,这些 Volume 里的信息就是仿佛是被 Kubernetes“投射”。Kubernetes 支持的 Projected Volume 有如下四种:
- Secret
- ConfigMap
- DownWarAPI
- ServiceAccountToken
1.1 Secret
Kubernetes 把 Pod 想要访问的东西存放在 etcd 中,然后通过在 Pod 的容器里挂载 volume 的方式来进行访问。存放数据库的凭证信息就是 Secret 最典型的应用场景之一。
apiVersion: v1 kind: Pod metadata: name: secret-gysl spec: containers: - name: secret-gysl image: busybox args: - sleep - "3600" volumeMounts: - name: secret-mysql-gysl mountPath: "/projected-volume-secret" readOnly: true volumes: - name: secret-mysql-gysl projected: sources: - secret: name: user - secret: name: passwd
在这个例子中,声明挂载的 Volume 的类型是 projected 类型。这个 Volume 的数据来源(sources)是名为 user 和 passwd 的 Secret 对象,分别对应的是数据库的用户名和密码。
在编写 yaml 文件的时候需要最后几行,secret 下面依然是需要进一步缩进的。
在 apply 以上 yaml 文件之后,我们会发现 Pod 的状态一直是 ContainerCreating ,原因是我们还没有创建相关的 secret 。使用以下命令进行创建:
kubectl create secret generic user --from-file=username.txt kubectl create secret generic passwd --from-file=passwd.txt
username.txt 和 passwd.txt 两个文件的内容分别如下:
cat username.txt gysl cat passwd.txt E#w23%dj2JK@
进入该 Pod:
kubectl exec -it secret-gysl sh
正常情况下,可以看到如下内容:
/ # ls -al /projected-volume-secret/ total 0 drwxrwxrwt 3 root root 120 Aug 1 07:25 . drwxr-xr-x 1 root root 60 Aug 1 07:25 .. drwxr-xr-x 2 root root 80 Aug 1 07:25 ..2019_08_01_07_25_08.650769588 lrwxrwxrwx 1 root root 31 Aug 1 07:25 ..data -> ..2019_08_01_07_25_08.650769588 lrwxrwxrwx 1 root root 17 Aug 1 07:25 passwd.txt -> ..data/passwd.txt lrwxrwxrwx 1 root root 19 Aug 1 07:25 username.txt -> ..data/username.txt / # cat /projected-volume-secret/username.txt gysl / # cat /projected-volume-secret/passwd.txt E#w23%dj2JK@
也可以通过 yaml 文件的方式来进行创建,以上命令转化为 yaml 如下:
apiVersion: v1 kind: Secret metadata: name: user type: Opaque data: username.txt: Z3lzbAo= --- apiVersion: v1 kind: Secret metadata: name: passwd type: Opaque data: passwd.txt: RSN3MjMlZGoySktACg==
该yaml 文件中的 data 部分的字段都是经过 base64 转码的:
cat username.txt |base64 Z3lzbAo= cat passwd.txt |base64 RSN3MjMlZGoySktACg==
使用上面的命令进入该 Pod 我们就可以看到跟之前操作一样的内容。上面我们使用了2个 secret 对象来进行本次实验。我们能否使用一个 secret 来达到一样的目标呢?
请看以下 yaml :
apiVersion: v1 kind: Pod metadata: name: secret-gysl spec: containers: - name: secret-gysl image: busybox args: - sleep - "3600" volumeMounts: - name: secret-mysql-gysl mountPath: "/projected-volume-secret" readOnly: true volumes: - name: secret-mysql-gysl projected: sources: # - secret: # name: passwd - secret: name: secret-gysl --- apiVersion: v1 kind: Secret metadata: name: secret-gysl type: Opaque data: user: Z3lzbAo= passwd: RSN3MjMlZGoySktACg==
进入 Pod 观察:
/projected-volume-secret # ls -al total 0 drwxrwxrwt 3 root root 120 Aug 1 06:55 . drwxr-xr-x 1 root root 60 Aug 1 06:55 .. drwxr-xr-x 2 root root 80 Aug 1 06:55 ..2019_08_01_06_55_22.687706782 lrwxrwxrwx 1 root root 31 Aug 1 06:55 ..data -> ..2019_08_01_06_55_22.687706782 lrwxrwxrwx 1 root root 13 Aug 1 06:55 passwd -> ..data/passwd lrwxrwxrwx 1 root root 11 Aug 1 06:55 user -> ..data/user
从目录结构和内容来看,差异并不大,多层软连接,一些隐藏文件。使用这样的方法创建的 secret 仅仅进行了转码,并未进行加密,生产环境中使用一般情况下需要使用加密插件。
1.2 ConfigMap
ConfigMap 与 Secret 的区别在于,ConfigMap 保存的是不需要加密的、应用所需的配置信息,用法几乎与 Secret 完全相同:可以使用 kubectl create configmap 从文件或者目录创建 ConfigMap,也可以直接编写 ConfigMap 对象的 YAML 文件。我们以 kube-controller-manager.conf 文件来演示一下。
创建 configMap:
kubectl create configmap kube-scheduler --from-file=/etc/kubernetes/conf.d/kube-controller-manager.conf
同样,我们也可以使用 yaml 来创建:
apiVersion: v1 kind: ConfigMap metadata: name: kube-controller-manager-gysl data: kube-controller-manager.conf: | KUBE_CONTROLLER_MANAGER_OPTS="--logtostderr=true --v=4 --master=127.0.0.1:8080 --leader-elect=true --address=127.0.0.1 --service-cluster-ip-range=10.0.0.0/24 --cluster-name=kubernetes --cluster-signing-cert-file=/etc/kubernetes/ca.d/ca.pem --cluster-signing-key-file=/etc/kubernetes/ca.d/ca-key.pem --root-ca-file=/etc/kubernetes/ca.d/ca.pem --service-account-private-key-file=/etc/kubernetes/ca.d/ca-key.pem"
就这样,kube-controller-manager.conf 配置文件的内容就被保存到了 kube-controller-manager-gysl 这个ConfigMap 中。
1.3 Downward API
Downward API 能让 Pod 里的容器能够直接获取到这个 Pod API 对象本身的信息。
apiVersion: v1 kind: Pod metadata: name: downward-api-gysl labels: zone: beijing cluster: gysl-cluster1 rack: rack-gysl spec: containers: - name: client-container image: busybox command: ["sh", "-c"] args: - while true; do if [[ -e /etc/podinfo/labels ]]; then echo -en '\n\n'; cat /etc/podinfo/labels; fi; sleep 5; done; volumeMounts: - name: podinfo mountPath: /etc/podinfo readOnly: false volumes: - name: podinfo projected: sources: - downwardAPI: items: - path: "labels" fieldRef: fieldPath: metadata.labels
Pod 的 Labels 字段的值,就会被 Kubernetes 自动挂载成为容器里的 /etc/podinfo/labels 文件。执行命令:
kubectl logs downward-api-gysl
看到的结果:
cluster="gysl-cluster1" rack="rack-gysl" zone="beijing" cluster="gysl-cluster1" rack="rack-gysl" zone="beijing" cluster="gysl-cluster1" rack="rack-gysl" zone="beijing"
Downward API 支持的字段已经非常丰富,比如:
1. 使用 fieldRef 可以声明使用: spec.nodeName - 宿主机名字 status.hostIP - 宿主机 IP metadata.name - Pod 的名字 metadata.namespace - Pod 的 Namespace status.podIP - Pod 的 IP spec.serviceAccountName - Pod 的 Service Account 的名字 metadata.uid - Pod 的 UID metadata.labels['<KEY>'] - 指定 <KEY> 的 Label 值 metadata.annotations['<KEY>'] - 指定 <KEY> 的 Annotation 值 metadata.labels - Pod 的所有 Label metadata.annotations - Pod 的所有 Annotation 2. 使用 resourceFieldRef 可以声明使用: 容器的 CPU limit 容器的 CPU request 容器的 memory limit 容器的 memory request
Downward API 能够获取到的信息,一定是 Pod 里的容器进程启动之前就能够确定下来的信息。而如果你想要获取 Pod 容器运行后才会出现的信息。比如,容器进程的 PID,那就肯定不能使用 Downward API 了,而应该考虑在 Pod 里定义一个 sidecar 容器。
1.4 Service Account
Service Account 对象的作用,就是 Kubernetes 系统内置的一种“服务账户”,它是 Kubernetes 进行权限分配的对象。比如,Service Account A,可以只被允许对 Kubernetes API 进行 GET 操作,而 Service Account B,则可以有 Kubernetes API 的所有操作的权限。
像这样的 Service Account 的授权信息和文件,实际上保存在它所绑定的一个特殊的 Secret 对象里的。这个特殊的 Secret 对象,就叫作ServiceAccountToken。任何运行在 Kubernetes 集群上的应用,都必须使用这个 ServiceAccountToken 里保存的授权信息,也就是 Token,才可以合法地访问 API Server。
因此,Kubernetes 项目的 Projected Volume 其实只有三种,因为第四种 ServiceAccountToken,只是一种特殊的 Secret 而已。
为了方便使用,Kubernetes 已经为你提供了一个的默认“服务账户”(default Service Account)。并且,任何一个运行在 Kubernetes 里的 Pod,都可以直接使用这个默认的 Service Account,而无需显示地声明挂载它。Kubernetes 在每个 Pod 创建的时候,自动在它的 spec.volumes 部分添加上了默认 ServiceAccountToken 的定义,然后自动给每个容器加上了对应的 volumeMounts 字段。这个过程对于用户来说是完全透明的。一旦 Pod 创建完成,容器里的应用就可以直接从这个默认 ServiceAccountToken 的挂载目录里访问到授权信息和文件。这个容器内的路径在 Kubernetes 里是固定的,即:/var/run/secrets/kubernetes.io/serviceaccount。
$ kubectl exec -it downward-api-gysl sh / # ls /var/run/secrets/kubernetes.io/serviceaccount ca.crt namespace token
这种把 Kubernetes 客户端以容器的方式运行在集群里,然后使用 default Service Account 自动授权的方式,被称作“InClusterConfig”,也是我最推荐的进行 Kubernetes API 编程的授权方式。
考虑到自动挂载默认 ServiceAccountToken 的潜在风险,Kubernetes 允许你设置默认不为 Pod 里的容器自动挂载这个 Volume。
二 相关资料
2.1 文中涉及到的yaml,参见本人GitHub。
2.2 不足之处还望诸位多多指教。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
阿里云史上最优惠活动:企业云服务器全场2折起!
阿里云作为国内No.1云服务器厂商,占领市场半壁江山,不仅靠的是性能、技术、售后等方面获得企业、站长青睐,更重要的是阿里云是营销狂魔,经常会推出一些促销折扣活动,这不,最近阿里云大张旗鼓地推出云主机爆款活动,全场2折起,话说这次活动相对比较良心的,没有以前那么多套路。如果有意向在阿里云上云,购买云服务器,那么这次活动一定不能错过。 云服务器爆款详情:必抢爆品 精选主机 活动地址:阿里云主机2折爆款活动 活动亮点:阿里云万年难得推出计算网络增强型sn1ne实例钜惠,8核16G 8M带宽配置3年仅需10000元。 计算网络增强型 sn1ne实例应用场景:计算网络增强型 sn1ne 实例适用于各类计算密集型应用,使用Intel Xeon Platinum 8163 处理器,适合高网络收发包场景,如:视频弹幕服务器、中大型 Web 服务器(高并发)、大型多人在线游戏 (MMO) 前端,数据分析和计算、利用 CPU 进行高精度编解码,渲染,基因计算等固定性能计算场景。特点是100%独享系统资源,不存在CPU限制和实例争抢,是真正的独享型服务器。如果你的业务属于企业级、B2B在线电子商务或各类计算...
- 下一篇
小企业如何选择阿里云服务器
之前已经在个人如何选择阿里云服务器文章中介绍了个人购买阿里云服务器的方法,今天来说下小企业如何选择阿里云服务器的配置。 企业和个人最大的区别就是企业面向的用户众多,对访问速度和数据安全性要求非常高。试想下你的网站三天两头被黑客攻击,网站被黑了,数据没了,这样的网站怎么能吸引到用户呢。最新优惠可选择,阿里云所有产品2折:点了详情对于个人站长,用户基数不是非常大,我认识的很多站长基本都是购买一台高配的ecs后,所有的东西都往ecs上安装,比如数据库,缓存服务等。这样做的缺陷是web服务和数据库存储没有进行分离。企业站点一般来说可以分为api和数据存储,api是面向外网用户的,为用户提供数据服务和展现ui。数据库则存储用户的重要数据,将存储和服务分开部署可以有效减小单台服务器的压力,第二则是数据安全更有保障。大家可以提前领取红包:红包地址所以对于企业站点来说,首先需要将api和数据库存储进行分开部署,以便分摊压力。在企业的前期,可能访问量很小,这时候所有的数据只需要直接访问数据库就可以了。随着访问量的增长,那么对于服务器的性能要求便会非常高,一般企业的场景是:读多于写。所以这时候可能需要引入...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Hadoop3单机部署,实现最简伪集群
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS8编译安装MySQL8.0.19