k8s教程(基础篇)-基本概念和术语(下)

简介: k8s教程(基础篇)-基本概念和术语(下)

3.6 有状态的应用集群

我们知道,Deployment 对象是用来实现无状态服务的多副本自动控制功能的,那么有状态的服务,比如: ZooKeeper:集群、MySQL 高可用集群(3 节点集群)、Kafka 集群等是怎么实现自动部署和管理的呢?

这个问题就复杂多了,这些一开始是依赖 StatefulSet 解决的,但后来发现对于一些复杂的有状态的集群应用来说,StatefulSet 还是不够通用和强大,所以后面又出现了 Kubernetes Operator

平台开发者借助 Operator 框架提供的 API,可以更方便地开发一个类似 StatefulSet 的控制器。在这个控制器里,开发者通过编码方式实现对目标集群的自定义操控,包括集群部署、故障发现及集群调整等方面都可以实现有针对性的操控,从而实现更好的自动部署和智能运维功能。

从发展趋势来看,未来主流的有状态集群基本都会以 Operator 方式部署到 Kubernetes集群中。

3.7 批处理应用

除了无状态服务、有状态集群、常见的第三种应用,还有批处理应用。批处理应用的特点是一个或多个进程处理一组数据(图像、文件、视频等),在这组数据都处理完成后,批处理任务自动结束。为了支持这类应用,Kubernetes 引入了新的资源对象一一 Job,下面是一个计算圆周率的经典例子:

Jobs 控制器提供了两个控制并发数的参数:completionsparallelism, completions 表示需要运行任务数的总数,parallelism 表示并发运行的个数。后来kubernetes增加了cronjob可以周期性的执行某个任务。

3.8 应用的配置

通过前面的学习,我们初步理解了三种应用建模的资源对象,总结如下。

  • 无状态服务的建模:Deployment
  • 有状态集群的建模:StatefulSet
  • 批处理应用的建模:Job

在进行应用建模时,应该如何解决应用需要在不同的环境中修改配置的问题呢?这就涉及 ConfigMap Secret 两个对象。

3.8.1 ConfigMap

用户将配置文件的内容保存到 ConfigMap 中,文件名可作为 key, value 就是整个文件的内容,多个配置文件都可被放入同一个 ConfigMap。

在建模用户应用时,在 Pod 里将 ConfigMap。定义为特殊的 Volume 进行挂载。在 Pod 被调度到某个具体 Node 上时,ConfigMap 里的配置文件会被自动还原到本地目录下,然后映射到 Pod 里指定的配置目录下,这样用户的程序就可以无感知地读取配置了。

在 ConfigMap 的内容发生修改后,Kubernetes 会自动重新获取 ConfigMap 的内容,并在目标节点上更新对应的文件。

3.8.2 Secret

Secrett也用于解决应用配置的问题,不过它解决的是对敏感信息的配置问题,比如数据库的用户名和密码、应用的数字证书、Tokn、SSH 密钥及其他需要保密的敏感配置。对于这类敏感信息,我们可以创建一个 Secret 对象,然后被 Pod 引用。Secret 中的数据要求以 BASE64 编码格式存放。注意,BASE64 编码并不是加密的,在 Kubernetes1.7 版本以后,Secret 中的数据才可以以加密的形式进行保存,更加安全。

3.9 应用的运维

3.9.1 HPA横向扩容

首先就是 HPA (Horizontal Pod Autoscaler),我们可以将 HPA 理解为 Pod 横向自动扩容,即自动控制 Pod 数量的增加或减少。通过追踪分析指定 Deployment 控制的所有目标Pod的负载变化情况,来确定是否需要有针对性地调整目标 Pod 的副本数量,这是 HPA 的实现原理。

例如:Kubernetes 内置了基于PodCPU利用率进行自动扩缩容的机制,应用开发者也可以自定义度量指标如每秒请求数,来实现自定义的 HPA 功能。下面是一个 HPA 定义的例子:

根据上面的定义,我们可以知道这个 HPA 控制的目标对象是一个名为 php-apacheDeployment里的 Pod 副本,当这些 Pod 副本的 CPU 利用率的值超过 90% 时,会触发自动动态扩容。

3.9.2 VPA垂直扩容

VPA (Vertical Pod Autoscaler) 即垂直 Pod 自动扩缩容,它根据容器资源使用率自动推测并设置 Pod 合理的CPU和内存的需求指标,从而更加精确地调度 Pod,实现整体上节省集群资源的目标,因为无须人为操作,因此也进一步提升了运维自动化的水平。

04 存储类

存储类的资源对象主要包括: VolumePersistent VolumePVCStorageClass

4.1 Volume(存储卷)

Volume Pod 中能够被多个容器访问的共享目录。

首先Kubernetes 中的 Volume 被定义在 Pod上,被一个 Pod 里的多个容器挂载到具体的文件目录下;其次,Kubernetes 中的 VolumePod 的生命周期相同,但与容器的生命周期不相关,当容器终止或者重启时,Volume 中的数据也不会丢失;最后,Kubernetes支持多种类型的 Volume,例如 GlusterFS、Ceph 等分布式文件系统。

Volume 的使用:在大多数情况下,我们先在 Pod 上声明一个 Volume,然后在容器里引用该 Volume并将其挂载(Mount)到容器里的某个目录下。

举例来说,若我们要给之前的 Tomcat Pod增加一个名为 datavolVolume,并将其挂载到容器的/mydata-data 目录下,则只对Pod 的定义文件做如下修正即可(代码中的粗体部分):

Kubernetes提供了非常丰富的Volume类型供容器使用,例如:临时目录、宿主机目录、共享存储等,下面对其中一些常见的类型进行说明。

4.1.1 emptyDir(临时目录)

一个 emptyDir 是在 Pod 分配到 Node 时创建的。从它的名称就可以看出,它的初始内容为空,并且无须指定宿主机上对应的目录文件,因为这是 Kubernetes 自动分配的一个目录,当 PodNode 上移除时,emptyDir 中的数据也被永久移除。

emptyDir 的一些用途如下。

  • 临时空间,例如用于某些应用程序运行时所需的临时目录,且无须永久保留。
  • 长时间任务执行过程中使用的临时目录。
  • 一个容器需要从另一个容器中获取数据的目录(多容器共享目录)。在默认情况下,emptyDir 使用的是节点的存储介质,例如磁盘或者网络存储。

还可以使用 emptyDir. Nedium 属性,把这个属性设置为“Memory”,就可以使用更快的基于内存的后端存储了。需要注意的是,这种情况下的 emptyDir 使用的内存会被计入容器的内存消耗,将受到资源限制和配额机制的管理。

4.1.2 hostPath(宿主机目录)

HostPath 为在 Pod 上挂载宿主机上的文件或目录,通常可以用于以下几方面:

  • 在容器应用程序生成的日志文件需要永久保存时,可以使用宿主机的高速文件系统对其进行存储。
  • 需要访问宿主机上 Docker 引擎内部数据结构的容器应用时,可以通过定hostPath为宿主机/var/Iib/docker目录,使容器内部的应用可以直接访问 Docker 的文件系统。

在使用这种类型的 Volume时,需要注意以下几点。

  • 在不同的 Node 上具有相同配置的 Pod,可能会因为宿主机上的目录和文件不同,而导致对 Volume上目录和文件的访问结果不一致。
  • 如果使用了资源配额管理,则 Kubernetes 无法将 hostPath 在宿主机上使用的资源纳入管理。

在下面的例子中使用了宿主机的/data目录定义了一个hostPath 类型的 Volume:

4.1.3 公有云Volume

公有云提供的 Volume 类型包括谷歌公有云提供的 GCEPersistentDisk、亚马逊公有云提供的 AWS Elastic Block Store (EBS Volume)等。当我们的Kubernetes集群运行在公有云上或者使用公有云厂家提供的 Kubernetes 集群时,就可以使用这类 Volume

4.1.4 其它类型的Volume

  • Iscsi:将 SCSI 存储设备上的目录挂载到 Pod 中。
  • nfs:将 NFS Server上的目录挂载到 Pod 中。
  • glusterfs:将开源 GlusterFS 网络文件系统的目录挂载到 Pod 中。
  • rbd:将 Ceph 块设备共享存储(Rados Block Device)挂载到Pod中。
  • gitRepo:通过挂载一个空目录,并从 Git 库克隆(clone)一个 git repository 以供 Pod 使用。
  • configmap:将配置数据挂载为容器内的文件。
  • secret:将 Secret数据挂载为容器内的文件。

4.1.5 动态存储

Volume属于静态管理的存储,即我们需要事先定义每个 Volume,然后将其挂载到 Pod 中去用,这种方式存在很多弊端,典型的弊端如下。

  • 配置参数烦琐,存在大量手工操作,违背了 Kubernetes 自动化的追求目标。
  • 预定义的静态 Volume 可能不符合目标应用的需求,比如容量问题、性能问题。

所以 Kubernetes 后面就发展了存储动态化的新机制,来实现存储的自动化管理。相关的核心对象(概念)有三个:Persistent Volume(简称 PV)、StorageClass、PVC

  • PV: 表示由系统动态创建(dynamically provisioned)的一个存储卷,可以被理解成 Kubernetes集群中某个网络存储对应的一块存储,它与 Volume 类似,但 PV 并不是被定义在 Pod 上的,而是独立于 Pod 之外定义的。PV 目前支持的类型主要有 gcePersistentDisk、AWSElasticBlockStore、AzureFile、AzureDisk、FC (Fibre Channel)、NFS、iSCSI、RBD (Rados Block Device)、CephFS、Cinder、GlusterFS、VsphereVolume、Quobyte Volumes、Mware Photon、Portworx Volumes、ScaleIO Volumes、ostPath、Local 等
  • StorageClass 用来描述和定义某种存储系统的特征,例如:StorageClass 有几个关键属性:provisioner、parameters 和 reclaimPolicy,系统在动态创建 PV 时会用到这几个参数。简单地说,provisioner 代表了创建 PV 的第三方存储插件,parameters 是创建 PV 时的必要参数,reclaimPolicy则表明了 PV 回收策略,回收策略包括删除或则保留。
  • PVC :StorageClass名称会在 PVC (PV Claim)中出现,下面就是一个典型的 PVC 定义:PVC 正如其名,表示应用希望申请的 PV 规格,其中重要的属性包括 accessModes(存储访问模式)、storageClassName(用哪种 StorageClass 来实现动态创建)及 resources(存储的具体规格)

有了以 StorageClass PVC 为基础的动态 PV 管理机制,我们就很容易管理和使用 Volume 了,只要在 Pod 里引用 PVC 即可达到目的,如下面的例子所示:

05 安全类

安全始终是 Kubernetes 发展过程中的一个关键领域。

从本质上来说 ,Kubernetes 可被看作一个多用户共享资源的资源管理系统,这里的资源主要是各种Kubernetes里的各类资源对象,比如 Pod、Service、Deployment 等。只有通过认证的用户才能通过 KubernetesAPI Server 查询、创建及维护相应的资源对象,理解这一点很关键。

5.1 Service Account

在默认情况下,Kubernetes在每个命名空间中都会创建一个默认的名称为 default Service Account,因此 Service Account 是不能全局使用的,只能被它所在命名空间中的 Pod 使用。通过以下命令可以查看集群中的所有 Service Account

Service Account 是通过 Secret 来保存对应的用户(应用)身份凭证的,这些凭证信息有 CA 根证书数据(ca.crt)和签名后的Token信息(Token)。

Token 信息中就包括了对应的Service Account的名称,因此 API Server 通过接收到的Token信息就能确定 Service Account 的身份。在默认情况下,用户创建一个 Pod 时,Pod 会绑定对应命名空间中的 default 这个 Service Account 作为其“公民身份证”。

Pod 里的容器被创建时,Kubernetes 会把对应的Secret对象中的身份信息(ca.crt、Token 等)持久化保存到容器里固定位置的本地文件中,因此当容器里的用户进程通过 Kubernetes 提供的客户端 API 去访问 API Server 时,这些API会自动读取这些身份信息文件,并将其附加到 HTTPS 请求中传递给API Server以完成身份认证逻辑。在身份认证通过以后,就涉及“访问授权”的问题,这就是 RBAC 要解决的问题了。

5.2 Role

首先我们要学习的是 Role 这个资源对象,包括 RoleClusterRole两种类型的角色。角色定义了一组特定权限的规则,比如可以操作某类资源对象。局限于某个命名空间的角色由Role对象定义,作用于整个 Kubernetes 集群范围内的角色则通过 Cluster Role 对象定义。

下面是 Role 的一个例子,表示在命名空间 default 中定义一个Role对象,用于授予对 Pod 资源的读访问权限,绑定到该 Role 的用户则具有对 Pod 资源的 getwatchlist权限:

5.2 Role Binding

接下来就是如何将 Role 与具体用户绑定(用户授权)的问题了。我们可以通过 RoleBinding ClusterRoleBinding 来解决这个问题。下面是一个具体的例子,在命名空间 default 中将“pod-reader”角色授予用户“Caden”,结合对应的 Role 的定义,表明这一授权将允许用户“Caden”从命名空间 default 中读取 pod:

RoleBinding 中使用 subjects(目标主体)来表示要授权的对象,这是因为我们可以授权三类目标账号:Group(用户组)、User(某个具体用户)和 Service Account (Pod 应用所使用的账号)。

5.3 NetworkPolicy(网络策略)

在安全领域,除了以上针对 API Server 访问安全相关的资源对象,还有一种特殊的资源对象一一 NetworkPolicy(网络策略),它是网络安全相关的资源对象,用于解决用户应用之间的网络隔离和授权问题。

NetworkPolicy 是一种关于 Pod 间相互通信,以及 Pod 与其他网络端点间相互通信的安全规则设定。

NetworkPolicy资源使用标签选择 Pod,并定义选定 Pod 所允许的通信规则。在默认情况下,Pod 间及Pod与其他网络端点间的访问是没有限制的,这假设了 Kubernetes集群被一个厂商(公司/租户)独占,其中部署的应用都是相互可信的,无须相互防范。但是,如果存在多个厂商共同使用一个Kubernetes集群的情况,则特别是在公有云环境中,不同厂商的应用要相互隔离以增加安全性,这就可以通过 NetworkPolicy 来实现了。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
1月前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
102 24
|
1月前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
139 6
|
5月前
|
Kubernetes 调度 Perl
在K8S中,Pod亲和性概念是什么?
在K8S中,Pod亲和性概念是什么?
|
3月前
|
Kubernetes 持续交付 微服务
深入浅出:理解 Kubernetes 核心概念
Kubernetes 是一个由 Google 开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它已成为微服务架构下的行业标准。本文深入浅出地介绍了 Kubernetes 的核心概念和组件,包括 Master 和 Node 组件、Pod、Service、Deployment 等,并提供了基本操作示例和实战应用,帮助你更好地管理和利用容器环境。
|
2月前
|
存储 Kubernetes 调度
K8S中的核心概念
【10月更文挑战第26天】云原生环境下的安全问题易被忽视,导致潜在风险。应用层渗透测试和漏洞扫描是检测安全的关键,尤其是对于CVE漏洞的修复。然而,常见误解认为安全由外部防护处理且不易引入问题。
|
5月前
|
Kubernetes 负载均衡 安全
在k8S中,网络模型概念是什么?
在k8S中,网络模型概念是什么?
|
5月前
|
存储 Kubernetes Cloud Native
在k8S中,rook概念是什么?
在k8S中,rook概念是什么?
|
5月前
|
JSON Kubernetes Cloud Native
在k8S中,CNI模型概念是什么?
在k8S中,CNI模型概念是什么?
|
5月前
|
消息中间件 Kubernetes 数据库
在k8S中,初始化容器(init container)概念原理是什么?
在k8S中,初始化容器(init container)概念原理是什么?
|
5月前
|
存储 Kubernetes Docker
在K8S中,与K8S相关基础概念有哪些?
在K8S中,与K8S相关基础概念有哪些?