当前位置: 首页 > 编程笔记 >

Kubernetes(k8s)基础介绍

呼延博易
2023-03-14
本文向大家介绍Kubernetes(k8s)基础介绍,包括了Kubernetes(k8s)基础介绍的使用技巧和注意事项,需要的朋友参考一下

之前我一直想学习Kubernetes,因为它听起来很有意思(如果你是希腊人,你会觉得这个名字很有问题),但我从来没有机会,因为我没有任何东西需要运行在集群中。而最近,我的工作中开始逐步涉及Kubernetes相关的事情,所以这次我抓住机会,开始查资料,但后来我发现目前所有的资料(包括官方教程)都过于冗长,结构也不合理,这让我一开始有点沮丧。

经过几天的研究,我开始逐步理解Kubernetes的核心理念,并且把他部署到了生产环境中。因为我的简历现在说自己是个“Kubernetes专家”,一个想法立刻诞生了:为什么不把我对这个系统的宽泛理解以及我已经耗费了几个小时的研究所收集的知识让更多人看到?虽然我无法说服自己不应该再写另一篇漫无目的的文章,但是我很快就明白了:
这就是那篇文章。

我在现有文章中遇到的主要问题是,在深入研究具体细节之前,我找不到的任何内容总结了这些组件是什么以及它们如何组合起来的高级概述。 而这种高屋建瓴的呈现方式是我学习最好的方式。我是以这种方式来写的,希望它也适合你。如果你知道任何描述了Kubernetes如何工作,而且让人容易理解的专家级的文章/教程,请不要告诉我,因为你在我需要你的时候你在哪里,现在我写了我的文章而你却没有及早把它拿出来。

另外请记住,我实际上只学习了Kubernetes一个星期左右,所以学得不会非常深入,有些可能是不准确的,希望没有什么错误,这里的信息应该足够让你达到运行简单集群的程度。

话虽如此,最后我发现Kubernetes中的概念还是非常简单的,虽然我确信有很多东西我还不知道。但是,我知道的事情就足以建立一个集群并让我们的应用在其上运行,而且我很确定它们足以让大多数人知道如何开始。

基本概念

我们需要做的第一件事是详细介绍Kubernetes的各个部分:

  • 控制平面(Control plane):顾名思义,这是控制其他一切的部分,这也是我一无所知的部分,因为我们只是向亚马逊付费,让亚马逊帮我们处理这部分。我的理解是,这是最好的决定,除非你是谷歌,否则你应该付费给一些公司,让他们为你管理。
  • 节点(Nodes):节点本质上就是一台服务器,就像您付费的物理机worker一样。 这是所有代码部署的地方,将裸服务器变成节点的方法是在其上安装Docker,kubelet,kube-proxy和其他一些东西。本文假设您的群集中已有一些worker。
  • 容器集(Pod):Pod是容器集合。 这是您的代码所在的位置,通常每个容器都有一个Pod,尽管您可能希望将一些密切相关的服务放在同一个Pod中。 Pod在单个节点上运行(但是一个节点可以运行许多Pod),这意味着Pod中的所有容器将具有相同的IP地址,并且它们可以通过连接到localhost上的彼此端口来相互通信。Pod在部署后无法更新,只能删除或替换它们。
  • 部署(Deployments): Deployment是您将Pod实际部署到群集的方式。 您可以在没有Deployment的情况下运行Pod,但如果没有Deployment,则无法轻松指定所需的副本数量,在失败时自动重新部署Pod,回滚到早期状态等。Deployment使代码生命周期管理变得更容易,并且您可以使用它来使Docker镜像在Kubernetes上运行。
  • 服务(Service):服务允许您从一个Pod打开端口到其他Pod,并指定一个Pod的DNS名称,以便能够查找并连接到群集中的其他Pod。
  • 入口(Ingress):Ingresses是你如何告诉你的Ingress控制器(通常是像Traefik这样的web server)向外界暴露什么,以及在哪个路径或主机名上。 入口将映射到将实际应答该请求的Pod。本教程也假设您已经配置了入口,虽然设置Traefik来做到这一点不应该非常困难(在用他们的教程时请使用Deployment方法)。

所有这些都可以使用命令行的kubectl创建,或者更安全地通过YAML文件创建,该文件将包含您要部署的内容的定义和详细信息(然后执行kubectl apply -f <yaml file>)。

概括地讲,您把容器放入pods中,这些pods将由deployment创建和部署,其网络将由service处理,并添加ingress以便外部世界可以访问您的服务器。

让我们逐个介绍这些部分,看看它们的YAML配置是什么样的。

The Pod

让我们看一下将在容器中运行Redis镜像的pod的YAML配置。 请记住,Pod并不是持久性的,所以你几乎不会直接使用它。 相反,您将使用deployment间接部署Pod,我们将在下面介绍。

以下配置示例仅供您进行修改。 你只需要看看它,然后继续阅读,不要停下来惊叹它的美丽。

正如您所看到的,它非常简单,您添加了一堆Kubernetes特定的东西,每个都只是复制粘贴,然后您声明此配置是为Pod,给它一个名称,指定在其中运行的容器和他们监听的端口,请删除整个文件吧,你已经准备好了!

Kubernetes官方文档中提供了更多关于Pod的信息。

The Deployment

以下是您实际运行上述Pod的方式,即使用deployment。 请记住,您根本不需要关注上面的Pod配置,我们将在deployment里重新定义它。

您会注意到这主要是上面的Pod配置,但有一些额外的配置,如副本(replica)等。这些定义了deployment的名称以及我们要部署的副本数量。 更改副本数量,将会部署更多template部分中指定的Pod。

Kubernetes官方文档中提供了更多关于Deployments的信息。

The Service

现在我们已经部署了一个Pod,我们需要将其端口暴露给集群的其余部分。 部署中的containerPort指令暴露了Docker端口,但实际上并不转发主机上的端口,因此多个Pod(不是同一Pod中的容器)可以使用相同的端口而不会发生冲突。

要将上面的端口实际暴露给集群上运行的其他Pod,我们需要为它创建一个Service。 这将创建转发端口所需的规则,并为我们提供DNS条目,我们可以使用该条目来解析该Pod的IP。

这会将Redis端口暴露给集群中的其他Pod,可以通过my-service:6379连接它。

要部署你的应用中更多部分,只需将另一个deployment和关联的Service添加到群集即可。 您可以使用与上面的Redis完全相同的方式部署主应用程序服务。

The Ingress

最后,我们可以使用Ingress将我们的服务暴露给互联网。 这里是使用Traefik的一个例子,虽然您可能实际上并不想将Redis暴露给外面的世界,但同样的方法适用于您自己的应用程序。

这一节配置是告诉Traefik你希望所有名为redis.yourdomain.com的主机上的流量都转发到我的服务端口6379。据我所知,这只是针对Traefik的配置。 在应用配置后,Pod将通过redis.yourdomain.com上的Traefik暴露到互联网。

我希望这篇文章对初学者有用。这篇文章很简短,因为Kubernetes的基础很短,但我们设法涵盖了如何以最小的麻烦来运行服务。

现在你应该懂Kubernetes是什么了!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小牛知识库的支持。如果你想了解更多相关内容请查看下面相关链接

 类似资料:
  • 本文向大家介绍数学基础介绍,包括了数学基础介绍的使用技巧和注意事项,需要的朋友参考一下 数学可以大致分为两类- 连续数学-它基于连续数字线或实数。它的特点是,在任意两个数字之间,几乎总是有无限个数字集合。例如,连续数学中的函数可以绘制成平滑的曲线而不会中断。 离散数学-涉及不同的价值观;也就是说,在任何两个点之间,都有可数的点。例如,如果我们有一组有限的对象,则该函数可以定义为具有这些对象的有序对

  • 像Echo (Alexa)、Siri和谷歌Translate这样的家喻户晓的产品名称至少有一个共同点。它们都是自然语言处理(NLP)应用的产物,NLP是本书的两个主要主题之一。NLP是一套运用统计方法的技术,无论是否有语言学的洞见,为了解决现实世界的任务而理解文本。这种对文本的“理解”主要是通过将文本转换为可用的计算表示,这些计算表示是离散或连续的组合结构,如向量或张量、图形和树。 从数据(本例中

  • 本文向大家介绍Javascript数组Array基础介绍,包括了Javascript数组Array基础介绍的使用技巧和注意事项,需要的朋友参考一下 Javascript,一门神奇的语言,它的数组也同样独特。我们要去其糟粕,取其精华,把常用的最优实践总结出来。如有错误,请指出。 javascript数组是一种类数组的对象,拥有对象的特性。当属性名是小而连续的整数时,应该使用数组,否则,使用对象。 数

  • 基础控制器【grace】源码及说明 所有的自定义控制器必须继承 grace 基础控制器,基础控制器内置了一些常用的方法以便您的开发!您也可以扩展 grace 来实现更为便捷的开发 ^_^ <?php class grace{ public $gets; //url 参数集合 public $tableName = null; //绑定数据表名称 public $tableKey =

  • 本文向大家介绍MongoDB的基础知识简介,包括了MongoDB的基础知识简介的使用技巧和注意事项,需要的朋友参考一下 1、文档、集合和数据库   a)、文档:因为MongoDB是面向文档的数据库,那么可想而知文档是它的基本单元,相当于关系型数据库中的行!     Ⅰ、它是由键值对组成的一个有序集;注:键不能为空且是字符串类型的。     Ⅱ、它不仅区分大小写,而且还区分数据类型;     Ⅲ、.

  • Container Container(容器)是一种便携式、轻量级的操作系统级虚拟化技术。它使用namespace隔离不同的软件运行环境,并通过镜像自包含软件的运行环境,从而使得容器可以很方便的在任何地方运行。 由于容器体积小且启动快,因此可以在每个容器镜像中打包一个应用程序。这种一对一的应用镜像关系拥有很多好处。使用容器,不需要与外部的基础架构环境绑定, 因为每一个应用程序都不需要外部依赖,更不