【Kubernetes理论篇】容器集群管理系统Kubernetes(K8S)

ops/2024/12/12 3:58:13/

Kubernetes集群部署+基本管理实战

这么好的机会,还在等什么!

01、Kubernetes 概述

K8S是什么

K8S 的全称为 Kubernetes (K12345678S),PS:“嘛,写全称也太累了吧,写”。不如整个缩写

K8s 作为缩写的结果来自计算“K”和“s”之间的八个字母,简称为K8S

k8s就是一种跨主机的容器集群编排工具

k8s他的全称Kubernetes 简称k8s,它是一种开源容器编排平台,用于自动化部署,扩展和管理化应用程序。它提供了种容器编排和管理的方式,还可以帮助开发人员更轻松的管理我们的应用程序。

K8S作用

K8S用于自动部署、扩展和管理“容器化(containerized)应用程序”的开源系统。

可以理解成 K8S 是负责自动化运维管理多个容器化程序(比如 Docker)的集群,是一个生态极其丰富的容器编排框架工具。

由来:

K8S由google的Borg系统(博格系统,google内部使用的大规模容器编排工具)作为原型,后经GO语言延用Borg的思路重写并捐献给CNCF基金会开源。

含义:

词根源于希腊语的 舵手、飞行员

官网:https://kubernetes.io

GitHub:https://github.com/kubernetes/kubernetes

K8S版本

目前一般是1.18~1.20,1.24版本后丢弃了docker(如需要使用需要第三方插件配合),目前最新版本是1.30,版本一年更新四次,1.24版本之后支持ivp6、还有集群化、添加了令牌重载授权服务

为什么要用 K8S

试想下传统的后端部署办法:把程序包(包括可执行二进制文件、配置文件等)放到服务器上,接着运行启动脚本把程序跑起来,同时启动守护脚本定期检查程序运行状态、必要的话重新拉起程序。

设想一下,如果服务的请求量上来,已部署的服务响应不过来怎么办?传统的做法往往是,如果请求量、内存、CPU超过阈值做了告警,运维人员马上再加几台服务器,部署好服务之后,接入负载均衡来分担已有服务的压力。

这样问题就出现了:从监控告警到部署服务,中间需要人力介入!那么,有没有办法自动完成服务的部署、更新、卸载和扩容、缩容呢?

而这就是 K8S 要做的事情:自动化运维管理容器化(Docker)程序。

K8S 的目标是让部署容器化应用简单高效。

K8S 解决了裸跑Docker 的若干痛点:

单机使用,无法有效集群

随着容器数量的上升,管理成本攀升

没有有效的容灾、自愈机制

没有预设编排模板,无法实现快速、大规模容器调度

没有统一的配置管理中心工具

没有容器生命周期的管理工具

没有图形化运维管理工具

K8S是Google开源的容器集群管理系统,在Docker等容器技术的基础上,为容器化的应用提供部署运行、资源调度、服务发现和动态伸缩等一系列完整功能,提高了大规模容器集群管理的便捷性。

其主要功能如下:

使用 Docker 等容器技术对应用程序包装(package)、实例化(instantiate)、运行(run)。

以集群的方式运行、管理跨机器的容器

解决 Docker 跨机器容器之间的通讯问题。

K8S 的自我修复机制使得容器集群总是运行在用户期望的状态。

k8s的主要功能

跨主机编排容器

更充分地利用硬件资源来最大化地满足企业应用的需求。

控制与自动化应用的部署与升级。

为有状态的应用程序挂载和添加存储器。

线上扩展或缩减容器化应用程序与它们的资源。

声明式的容器管理,保证所部署的应用按照我们部署的方式运作。

通过自动布局、自动重启、自动复制、自动伸缩实现应用的状态检查与自我修复。

为多个容器提供服务发现和负载均衡,使得用户无需考虑容器IP问题。(通过service)

K8S 的特性

弹性伸缩

使用命令、UI或者基于CPU使用情况自动快速扩容和缩容应用程序实例,保证应用业务高峰并发时的高可用性;业务低峰时回收资源,以最小成本运行服务。

假设2 台机器, 提供 web 服务网站高并发, 根据系统资源占比来自动扩展机器 、高并发一旦过去了,他就会自动收机器

自我修复

在节点故障时重新启动失败的容器,替换和重新部署,保证预期的副本数量;杀死健康检査失败的容器,并且在未准备好之前不会处理客户端请求,确保线上服务不中断。

业务机器一旦坏掉 ,如果用户期望值是1台,他会自动重拉起一个1台机器

服务发现和负载均衡

K8S为多个容器提供一个统一访问入口(内部IP地址和一个DNS名称),并且负载均衡关联的所有容器,使得用户无需考虑容器IP问题。

如果有一台服务器坏了,它会通过标签+ip地址绑定新的服务器

自动发布(默认滚动发布模式)和回滚

K8S采用滚动更新策略更新应用,一次更新一个或者部分Pod,而不是同时删除所有Pod,如果更新过程中出现问题,将回滚更改,确保升级不影响业务。

K8S可以在线更新,假设我有3台nginx版本需要升级,他会先自动更新1台,对外发布两台,

如果更新好了,没问题了,再更新下一台

集中化配置管理和密钥管理

管理机密数据和应用程序配置,而不需要把敏感数据暴露在镜像里,提高敏感数据安全性。并可以将一些常用的配置存储在K8S中,方便应用程序使用。

存储编排,支持外挂存储并对外挂存储资源进行编排

挂载外部存储系统,无论是来自本地存储,公有云(如AWS),还是网络存储(如NFS、Glusterfs、Ceph)都作为集群资源的一部分使用,极大提高存储使用灵活性。

任务批处理运行

提供一次性任务,定时任务;满足批量数据处理和分析的场景。

————————————————

学习Kubernetes集群部署+基本管理实战


http://www.ppmy.cn/ops/141156.html

相关文章

从0到1实现项目Docker编排部署

在深入讨论 Docker 编排之前,首先让我们了解一下 Docker 技术本身。Docker 是一个开源平台,旨在帮助开发者自动化应用程序的部署、扩展和管理。自 2013 年推出以来,Docker 迅速发展成为现代软件开发和运维领域不可或缺的重要工具。 Docker 采…

工具篇:(一)MacOS 下使用 Navicat 管理 MySQL 数据库:详细图文教程与常见问题解决

MacOS 下使用 Navicat 管理 MySQL 数据库:详细图文教程与常见问题解决 在这篇文章中,我将分享如何在 macOS 上使用 Navicat 来管理 MySQL 数据库。这是一份详细的教程,包括 Navicat 的下载、安装、配置以及使用步骤,并附上亲测的…

【Golang】Go语言编程思想(二):函数式编程

函数式编程 函数与闭包 支持函数式编程的语言当中,函数是一等公民,参数、变量、返回值都可以是函数。 以 adder 为例,下例实现了一个函数式编程: package mainimport "fmt"func adder() func(int) int {sum : 0retu…

华纳云:哪些行业会用到大硬盘存储服务器?

大硬盘存储服务器被广泛应用于需要大量数据存储、处理和管理的多个领域。以下是一些典型的应用场景: 1. 数据中心和云计算:数据中心需要为各种服务提供后端支持,包括云存储、虚拟化、数据库管理和备份恢复等。大数据硬盘服务器能够提供必要的…

评估大语言模型(LLM)在分子预测任务能够理解分子几何形状性能

摘要 论文地址:https://arxiv.org/pdf/2403.05075 近年来,机器学习模型在各个领域越来越受欢迎。学术界和工业界都投入了大量精力来提高机器学习的效率,以期实现人工通用智能(AGI)。其中,大规模语言模型&a…

thinkphp框架使用command实现队列功能

背景 ThinkPHP命令行工具持久化运行的应用场景包括:队列处理,定时任务、后台服务等。本次实战是实现队列处理数据。 步骤1 application目录command.php增加 return [app\admin\command\Crud,app\admin\command\Menu,app\admin\command\Install,app\a…

在GITHUB上传本地文件指南(详细图文版)

这份笔记简述了如何在GITHUB上上传文件夹的详细策略。 既是对自己未来的一个参考,又希望能给各位读者带来帮助。 详细步骤 打开目标文件夹(想要上传的文件夹) 右击点击git bash打开 GitHub创立新的仓库后,点击右上方CODE绿色按…

【LLMs】用LM Studio本地部署离线大语言模型

文章目录 一、下载LM Studio二、下载大语言模型1. 查看模型介绍2. 点击模型文件进行下载2.1 完整下载2.2 部分下载 三、加载模型1. 打开LM Studio图形化界面,点击**My Models**2. 然后,点击“...”,选择“change”,选择刚下载好的…