【云原生】Kubernetes 概述

Kubernetes 概述

1.Kubernetes 简介

Kubernetes 是一个可移植的、可扩展的、用于管理容器化工作负载和服务的开源平台,它简化(促进)了声明式配置和自动化。它有一个庞大的、快速增长的生态系统。Kubernetes 的服务、支持和工具随处可见。

Kubernetes 一词源于希腊语,意为舵手或飞行员。 2014 2014 2014 年,谷歌开放了 Kubernetes 项目的源代码。Kubernetes 基于谷歌在大规模运行生产工作负载方面的 15 15 15 年经验,以及来自社区的最佳想法和实践。

在这里插入图片描述
使用 Kubernetes, 我们可以快速高效地响应客户需求:

  • 快速、可预测地部署你的应用程序。
  • 拥有即时扩展应用程序的能力。
  • 不影响现有业务的情况下,无缝地发布新功能。
  • 优化硬件资源,降低成本。

Kubernetes 的目标是构建一个软件和工具的生态系统,以减轻你在公共云或私有云运行应用程序的负担。

1.1 回顾

让我们把时间回溯到从前,看看为什么 Kubernetes 是如此有用。

在这里插入图片描述
传统部署时代:在早期,组织在物理服务器上运行应用程序。无法为物理服务器中的应用程序定义资源边界,这导致了资源分配问题。例如,如果一个物理服务器上运行多个应用程序,那么在某些情况下,一个应用程序将占用大部分资源,从而导致其他应用程序性能下降。对此的解决方案是在不同的物理服务器上运行每个应用程序。但是,由于资源没有得到充分利用,而且维护许多物理服务器的成本很高,所以无法进行扩展。

虚拟化部署时代:作为一种解决方案,引入了虚拟化。它允许你在单个物理服务器的 CPU 上运行多个虚拟机 VM。虚拟化允许在 VM 之间隔离应用程序,并提供一定程度的安全性,因为一个应用程序的信息不能被另一个应用程序自由访问。

虚拟化可以更好地利用物理服务器中的资源,并提供更好的可伸缩性,因为可以方便地添加或更新应用程序,从而降低硬件成本,等等。通过虚拟化,你可以将一组物理资源表示为一次性虚拟机集群。

每个 VM 是一个完整的机器,运行所有组件,包括它自己的操作系统,运行在虚拟硬件之上。

容器部署时代:容器类似于 VM,但是它们具有宽松的隔离属性,以便在应用程序之间共享操作系统 OS。因此,容器被认为是轻量级的。与 VM 类似,容器有自己的文件系统、CPU、内存、进程空间等等。由于它们与底层基础设施解耦,因此可以跨云和 OS 发行版移植。

容器已经变得很流行,因为它们提供了额外的好处,比如:

  • 敏捷应用程序创建和部署:与使用 VM 镜像相比,增加了容器镜像创建的方便性和效率。
  • 持续开发、集成和部署:提供可靠且频繁的容器镜像构建和部署,具有快速且轻松的回滚。
  • 开发和运维关注点分离:在构建 / 发布时而不是部署时创建应用程序容器镜像,从而将应用程序与基础设施分离。
  • 可观察性:不仅能显示操作系统级的信息和指标,还能显示应用程序的健康状况和其他信号。
  • 跨开发、测试和生产的环境一致性:在笔记本电脑上运行与在云上运行完全相同。
  • 云和操作系统发布的可移植性:运行在 Ubuntu、RHEL、CoreOS、on-prem、谷歌 Kubernetes 引擎,和其他任何地方。
  • 以应用程序为中心的管理:将抽象级别从在虚拟硬件上运行操作系统提高到使用逻辑资源在操作系统上运行应用程序。
  • 松散耦合、分布式、弹性、解放的微服务:应用程序被分解成更小的独立部分,可以动态地部署和管理 —— 而不是运行在一台大型单用途机器上的单片堆栈。
  • 资源隔离:可预测的应用程序性能。
  • 资源利用:效率高,密度大 。

1.2. 为什么需要 Kubernetes?它能做什么?

容器是捆绑和运行应用程序的好方法。在生产环境中,你需要管理运行应用程序的容器,并确保没有停机时间。例如,如果一个容器发生故障,则需要启动另一个容器。如果这个行为由一个系统来处理不是更容易吗?

Kubernetes 为你提供了一个能够弹性地运行分布式系统的框架。它负责处理应用程序的扩展和故障转移,提供部署模式,等等。

Kubernetes为你提供:

  • 服务发现和负载平衡:Kubernetes 可以使用 DNS 名称或自己的 IP 地址公开容器。如果到容器的通信量很高,Kubernetes 能够实现负载平衡并分配网络通信量,从而使部署保持稳定。
  • 存储编排:Kubernetes 允许你自动挂载自己选择的存储系统,比如本地存储、公有云提供商等等。
  • 自动滚动更新和回滚:可以使用 Kubernetes 描述所部署容器的期望状态,并且可以以受控的速率将实际状态更改为期望状态。
  • 自动包装:你只需为 Kubernetes 提供一组节点,它便可以使用这些节点来运行容器化的任务。告诉 Kubernetes 每个容器需要多少 CPU 和内存(RAM)。Kubernetes 可以在你的节点上放置容器,以充分利用你的资源。
  • 自动重启:Kubernetes 会重新启动失败的容器,替换容器,杀死不响应用户定义的健康检查的容器,并且在它们准备好服务之前不会将他们暴露给客户端。
  • 秘密和配置管理:Kubernetes 允许你存储和管理敏感信息,比如密码、OAuth 令牌和 ssh 密钥。你可以部署和更新秘密和应用程序配置,而无需重新构建容器映像,也无需在堆栈配置中公开秘密。

1.3. Kubernetes 不是什么

Kubernetes 不是一个传统的、包罗万象的 PaaS 系统。由于 Kubernetes 是在容器级别而不是在硬件级别操作的,所以它提供了一些 PaaS 产品常见的通用特性,例如部署、扩展、负载平衡、日志记录和监视。但是,Kubernetes 不是单片的,这些默认的解决方案是可选的和可插拔的。Kubernetes 为构建开发人员平台提供了构建块,但是在重要的地方保留了用户的选择和灵活性。

  • 不限制所支持的应用程序类型。Kubernetes 的目标是支持非常多样化的工作负载,包括无状态、有状态和数据处理工作负载。如果一个应用程序可以在容器中运行,那么它应该可以 在Kubernetes 上运行。
  • 不部署源代码,也不构建应用程序。持续集成、交付和部署(CI/CD)工作流由组织文化和偏好以及技术需求决定。
  • 不提供应用级服务,如中间件(例如,消息总线)、数据处理框架(例如,Spark)、数据库(例如,MySQL)、缓存,也不提供集群存储系统(例如,Ceph)作为内置服务。这些组件可以运行在 Kubernetes 上,并且可以由运行在 Kubernetes 上的应用程序通过可移植的机制(例如,Open Service Broker)访问。
  • Kubernetes 允许用户选择其他的日志记录,监控和告警系统
  • 不提供也不强制要求配置语言/系统(例如,jsonnet)。它提供了一个声明性 API,可以被任意形式的声明性规范作为目标。
  • 不提供也不采用任何全面的机器配置、维护、管理或自修复系统
  • 此外,Kubernetes 不仅仅是一个编排系统。事实上,它消除了对编排的需要。编排的技术定义是执行一个已定义的工作流:首先执行 A,然后执行 B,然后执行 C。相反,Kubernetes 包括一套独立、可组合的控制过程,通过声明式语法使其连续地朝着期望状态驱动当前状态。你怎么从 A 点到 C 点都不重要,只要告诉到 C 的状态即可。

2.Kubernetes 组件

当你部署 Kubernetes 的时候,你会得到一个集群。

一个集群是一组机器,称为节点(nodes),它们运行由 Kubernetes 管理的容器化应用程序。一个集群至少有一个工作节点(worker node)和一个主节点(master node)。

工作节点承载应用程序的组件。主节点管理集群中的工作节点和 pods。多个主节点用于提供具有故障转移和高可用性的集群。

下面是 Kubernetes 集群的关系图:

在这里插入图片描述

2.1 Master 组件

Master 组件提供集群的 控制面板。Master 组件对集群做出全局决策(例如,调度),Master 组件检测并响应集群事件(例如,当部署的 replicas 字段不满足时启动一个新的 pod

Master 组件可以在集群中的任何机器上运行。但是,为了简单起见,设置脚本通常在同一台机器上启动所有 Master 组件,并且不在这台机器上运行用户容器。

(1)kube-apiserver

API 服务器是一个 Kubernetes 面板控制组件,用于公开 Kubernetes API。它是 Kubernetes 控制面板的前端。

Kubernetes API 服务器的主要实现是 kube-apiserverkube-apiserver 被设计成水平伸缩 —— 也就是说,它通过部署更多实例来伸缩。你可以运行 kube-apiserver 的多个实例,并在这些实例之间平衡流量。

(2)etcd

一致性和高可用的键值存储用作 Kubernetes 的所有集群数据备份存储。

如果你的 Kubernetes 集群使用 etcd 作为其备份存储,请确保对这些数据有备份计划。

(3)kube-scheduler

监视没有分配节点的新创建的 pod,并为它们选择要运行的节点。

(4)kube-controller-manager

运行控制器的组件,从逻辑上讲,每个控制器都是一个单独的进程,但是为了降低复杂性,它们都被编译成一个单一的二进制文件,并在一个进程中运行。

这些控制器包括:

  • Node Controller:节点控制器,负责发现和响应节点故障。
  • Replication Controller:副本控制器,负责为系统中的每个副本控制器对象维护正确的 pod 数量。
  • Endpoints Controller:端点控制器,填充端点对象(即,连接服务和 pod)。
  • Service Account & Token Controllers:为新的名称空间创建默认帐户和 API 访问令牌。

(5)cloud-controller-manager

云控制器-管理器,运行与底层云提供商交互的控制器

2.2 Node 组件

Node 组件在每个节点上运行,维护运行的 pods 并提供 Kubernetes 运行时环境。

(1)kubelet

kubelet 是一个代理,它运行在集群中的每个节点上,它确保容器在一个 pod 中运行。kubelet 只管理由 Kubernetes 创建的容器。

(2)kube-proxy

kube-proxy 是运行在集群中每个节点上的网络代理,是实现 Kubernetes 服务概念的一部分。

kube-proxy 维护节点上的网络规则。这些网络规则允许从集群内外的网络会话与 pod 进行网络通信。

如果有可用的操作系统包过滤层,kube-proxy 将使用它。否则,kube-proxy 将转发流量本身。

(3)Container Runtime

容器运行时是负责运行容器的软件。

Kubernetes 支持多个容器运行时:DockercontainerdcriorktletKubernetes CRI(容器运行时接口)的任何实现。

2.3 Addons(插件)

(1)DNS

虽然其他插件不是严格要求的,但所有 Kubernetes 集群都应该有集群 DNS,因为许多示例都依赖于它。

(2)Web UI(Dashboard)

Dashboard 是一个通用的、基于 Web 的 Kubernetes 集群用户界面。它允许用户管理和排除集群中运行的应用程序和集群本身的故障。

(3)Container Resource Monitoring

容器资源监控记录中央数据库中容器的一般时间序列指标,并提供用于浏览该数据的 UI。

(4)Cluster-level Logging

集群级别的日志记录机制负责将容器日志保存到具有搜索/浏览界面的中央日志存储中。

3.总结

Kubernetes 特点总结:

  • 可移植:无论公有云、私有云、混合云还是多云架构都全面支持。
  • 可扩展:它是模块化、可插拔、可挂载、可组合的,支持各种形式的扩展。
  • 自修复:它可以自保持应用状态、可自重启、自复制、自缩放的,通过声明式语法提供了强大的自修复能力。

Kubernetes 建立在 Google 公司 15 15 15 年的运维经验基础之上,Google 所有的应用都运行在容器上。


https://kubernetes.io/docs/concepts/overview/
https://kubernetes.io/docs/concepts/overview/components/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/33658.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

消息队列kafka及zookeeper机制

一、zookeeper1.1 zookeeper简介1.2 zookeeper工作机制1.3 Zookeeper特点1.4 Zookeeper 数据结构1.5 Zookeeper 应用场景1.5.1 统一命名服务1.5.2 统一配置管理1.5.3 统一集群管理1.5.4 服务器动态上下线1.5.5 软负载均衡 1.6 Zookeeper 选举机制1.6.1 第一次启动选举机制1.6.2…

Jenkins 使用

Jenkins 使用 文章目录 Jenkins 使用一、jenkins 任务执行二、 Jenkins 连接gitee三、Jenkins 部署静态网站 一、jenkins 任务执行 jenkins 创建 job job的名字最好是有意义的 restart_web_backend restart_web_mysql[rootjenkins ~]# ls /var/lib/jenkins/ config.xml …

W5500-EVB-PICO作为TCP Client 进行数据回环测试(五)

前言 上一章我们用W5500-EVB-PICO开发板通过DNS解析www.baidu.com(百度域名)成功得到其IP地址,那么本章我们将用我们的开发板作为客户端去连接服务器,并做数据回环测试:收到服务器发送的数据,并回传给服务器…

SAP MM学习笔记16-在库品目评价

在库品目评价是指评估物料。具体比如物料价格,数量,保管场所等发生变化的时候,判断是否发生了变化,要不要生成 FI票,用哪个FI科目来进行管理等内容就叫在库品目评价。 在库品目评价有很多层级,这里先讲3兄弟…

在Linux虚拟机内配置nginx以及docker

目录 1、nginx源码包编译以及安装依赖 1、配置安装所需的编译环境 2、安装函数库(pcre、zlib、openssl) 2、安装nginx 1、获取源码包 2、解压编译 3、启动nginx服务 1、关闭防火墙 2、运行nginx 3、使用本地浏览器进行验证 3、安装docker 1、…

每次执行@Test方法前都执行一次DB初始化(SpringBoot Test + JUnit5环境)

引言 在执行单元测试时,可以使用诸如H2内存数据库替代线上的Mysql数据库等,如此在执行单元测试时就能尽可能模拟真实环境的SQL执行,同时也无需依赖线上数据库,增加了测试用例执行环境的可移植性。而使用H2数据库时,通…

Oracle DB 安全性 : TDE HSM TCPS Wallet Imperva

• 配置口令文件以使用区分大小写的口令 • 对表空间进行加密 • 配置对网络服务的细粒度访问 TCPS 安全口令支持 Oracle Database 11g中的口令: • 区分大小写 • 包含更多的字符 • 使用更安全的散列算法 • 在散列算法中使用salt 用户名仍是Oracle 标识…

【JavaEE】Spring Boot - 日志文件

【JavaEE】Spring Boot 开发要点总结(3) 文章目录 【JavaEE】Spring Boot 开发要点总结(3)1. 日志有什么作用2. 日志格式2.1 日志框架原理 3. 日志的打印3.1 System.out.println3.2 使用日志框架3.3 日志级别3.3.1 设置默认日志显…

深度学习(36)—— 图神经网络GNN(1)

深度学习(36)—— 图神经网络GNN(1) 这个系列的所有代码我都会放在git上,欢迎造访 文章目录 深度学习(36)—— 图神经网络GNN(1)1. 基础知识2.使用场景3. 图卷积神经网…

提高测试用例质量的6大注意事项

在软件测试中,经常会遇到测试用例设计不完整,用例没有完全覆盖需求等问题,这样往往容易造成测试工作效率低下,不能及时发现项目问题,无形中增加了项目风险。 因此提高测试用例质量,就显得尤为重要。一般来说…

电脑开不了机如何解锁BitLocker硬盘锁

事情从这里说起,不想看直接跳过 早上闲着无聊,闲着没事干,将win11的用户名称改成了含有中文字符的用户名,然后恐怖的事情发生了,蓝屏了… 然后就是蓝屏收集错误信息,重启,蓝屏收集错误信息&…

C#小轮子:自动连续Ping网络地址

文章目录 前言Ping代码异步问题 前言 工作中,我们经常用到Ping这个指令,有时候我们需要Ping整个网段来查看这个网段上面有什么设备,哪些Ip地址是通的,这个时候就需要Ping指令 Ping 代码 我这个是批量Ping的代码,而…

python爬虫实战(2)--爬取某博热搜数据

1. 准备工作 使用python语言可以快速实现,调用BeautifulSoup包里面的方法 安装BeautifulSoup pip install BeautifulSoup完成以后引入项目 2. 开发 定义url url https://s.微博.com/top/summary?caterealtimehot定义请求头,微博请求数据需要cookie…

OpenAI允许网站阻止其网络爬虫;谷歌推出类似Grammarly的语法检查功能

🦉 AI新闻 🚀 OpenAI推出新功能,允许网站阻止其网络爬虫抓取数据训练GPT模型 摘要:OpenAI最近推出了一个新功能,允许网站阻止其网络爬虫从其网站上抓取数据训练GPT模型。该功能通过在网站的Robots.txt文件中禁止GPTB…

datax抽取库名带点的表遇到的问题

一、描述任务 使用Datax抽取mysql中的数据到hive的wedw_ods层中,mysql的库名为:b.p.n.p 表名为:bene_group 二、datax.json脚本生成 因为datax的脚本是自动生成的,生成的格式如下: {"core": {},"jo…

python接口自动化测试框架2.0,让你像Postman一样编写测试用例,支持多环境切换、多业务依赖、数据库断言等

项目介绍 接口自动化测试项目2.0 软件架构 本框架主要是基于 Python unittest ddt HTMLTestRunner log excel mysql 企业微信通知 Jenkins 实现的接口自动化框架。 前言 公司突然要求你做自动化,但是没有代码基础不知道怎么做?或者有自动化…

部署模型并与 TVM 集成

本篇文章译自英文文档 Deploy Models and Integrate TVM tvm 0.14.dev0 documentation 更多 TVM 中文文档可访问 →Apache TVM 是一个端到端的深度学习编译框架,适用于 CPU、GPU 和各种机器学习加速芯片。 | Apache TVM 中文站 本节介绍如何将 TVM 部署到各种平台&…

搭建Repo服务器

1 安装repo 参考&#xff1a;清华大学开源软件镜像站:Git Repo 镜像使用帮助 2 创建manifest仓库 2.1 创建仓库 git init --bare manifest.git2.2 创建default.xml文件 default.xml文件内容&#xff1a; <?xml version"1.0" encoding"UTF-8" ?…

基于Googlenet深度学习网络的人员行为动作识别matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 1. 原理 1.1 深度学习与卷积神经网络&#xff08;CNN&#xff09; 1.2 GoogLeNet 2. 实现过程 2.1 数据预处理 2.2 构建网络模型 2.3 数据输入与训练 2.4 模型评估与调优 3. 应用领域…

STM32 LL库开发

一、STM32开发方式 标准库开发&#xff1a;Standard Peripheral Libraries&#xff0c;STDHAL库开发&#xff1a;Hardware Abstraction Layer&#xff0c;硬件抽象层LL库开发&#xff1a;Low-layer&#xff0c;底层库 二、HAL库与LL库开发对比 ST在推行HAL库的时候&#xff0c;…