一文把Docker、Kubernetes搞懂:什么是Docker?什么是Kubernetes?Docker和Kubernetes有什么关系和区别?通俗解释Docker、Kubernetes

一、Docker解决的问题

1、统一标准

● 应用构建
○ Java、C++、JavaScript——编程各异
○ 打成软件包
○ .exe(类似Windows,最终也只是生产exe执行)
○ 使用docker build … 打包成 镜像——这就类似于exe

● 应用分享
○ 所有软件的镜像放到一个指定地方 docker hub
○ 类似——安卓,应用市场

● 应用运行
○ 统一标准的 镜像
○ docker run 就好(以前的方法是java -ja…、C++编译再整很多东西等等都不一样)

● …

2、容器化时代

区别于虚拟化技术:

  • 容器化其实是Linux做的,docker对此进行简单封装。docker不带操作系统,既然有了操作系统,只需做一些差异化的工作,所以每一个应用只是差异化环境
    在这里插入图片描述
  • 为了隔离应用,使用了虚拟化。但是镜像系统都很大占用。移植起来,需要应用带上整个虚拟机和环境,一起移植到其他设备——非常重量级
    在这里插入图片描述

3、资源隔离

● cpu、memory资源隔离与限制
● 访问设备隔离与限制
● 网络隔离与限制
● 用户、用户组隔离限制
● …

4、架构

在这里插入图片描述
● Docker_Host:
○ 安装Docker的主机
● Docker Daemon:
○ 运行在Docker主机上的Docker后台进程
● Client:
○ 操作Docker主机的客户端(命令行、UI等)
● Registry:
○ 镜像仓库
○ Docker Hub
● Images:
○ 镜像,带环境打包好的程序,可以直接启动运行
● Containers:
○ 容器,由镜像启动起来正在运行中的程序

交互逻辑:

装好Docker,然后去 软件市场 寻找镜像,下载并运行,查看容器状态日志等排错

二、Kubernetes基本

1. 首先解决Kubernetes的出现解决了什么问题?

在这里插入图片描述

  • 传统的部署模式中,应用部署在一个操作系统中。如果一个应用内存泄露了,就会把其他应用挤下线,非常不安全
  • 虚拟化的部署中,一个应用炸了只能影响到虚拟机内
  • 容器化的部署中,在原有的操作系统中有了容器化的运行环境,然后应用就会以容器化的形式运行起来。也能做到资源隔离且轻便

容器化也会带来一个问题:当服务模块众多,每个小项目的微服务都已以容器化的形式部署,并且放到很多台服务器。以前用docker run跑一两个应用,人肉可以运维和操作 ,但是如果几千个容器的话,就难以管理 。因此大规模容器编排系统应运而生(编:同一个应用的容器划分成一组;排:比如A应用在这个服务器不够了,就在别的服务器拿来扩充几个

2. kubernetes特性

kubernetes具有以下特性:
● 服务发现和负载均衡:

  • 服务发现:发现宕机有问题的容器,不降任务给他
  • 负载均衡:Kubernetes 可以使用 DNS 名称或自己的 IP 地址公开容器,如果进入容器的流量很大, Kubernetes 可以负载均衡并分配网络流量,从而使部署稳定。

● 存储编排
Kubernetes 允许你自动挂载你选择的存储系统,例如本地存储、公共云提供商等。应用需要内存则找k8s要,k8s开辟一块存储空间。应用删了后存储也没了
● 自动部署和回滚
你可以使用 Kubernetes 描述已部署容器的所需状态,它可以以受控的速率将实际状态 更改为期望状态。例如,你可以自动化 Kubernetes 来为你的部署创建新容器, 删除现有容器并将它们的所有资源用于新容器。——回滚到上一次部署的版本
● 自动完成装箱计算
Kubernetes 允许你指定每个容器所需 CPU 和内存(RAM)。 当容器指定了资源请求时,Kubernetes 可以做出更好的决策来管理容器的资源。——指定了这么多内存,超过了就会被杀掉
● 自我修复
Kubernetes 重新启动失败的容器、替换容器、杀死不响应用户定义的 运行状况检查的容器,并且在准备好服务之前不将其通告给客户端。——一个机器挂了,可以将其中的容器部署到其他机器
● 密钥与配置管理
Kubernetes 允许你存储和管理敏感信息,例如密码、OAuth 令牌和 ssh 密钥。 你可以在不重建容器镜像的情况下部署和更新密钥和应用程序配置,也无需在堆栈配置中暴露密钥。

Kubernetes 为你提供了一个可弹性运行分布式系统的框架。 Kubernetes 会满足你的扩展要求、故障转移、部署模式等。
例如,Kubernetes 可以轻松管理系统的 Canary 部署。

二、Kubernetes架构

1. 工作方式

Kubernetes Cluster = N Master Node + N Worker Node:N主节点+N工作节点; N>=1

2. 组件架构

工作起来的核心组件如下图的右侧所示:
在这里插入图片描述

为便于理解,以硅谷集团部署飞机项目为例:

  1. 一个飞机项目下设的的三个节点即东厂、西厂、南厂 ——node
  2. 主节点master为硅谷总部——control plane
  3. 决定要干什么的决策者(任何人如厂里的都找不到决策者)——controller manager
  4. 整个集团运行的核心数据得用资料库保存——etcd(类似redis的存储库,就像mysql)
  5. 负责将数据存进资料库、干杂活则需要秘书干——API server
  6. 负责看哪些厂可以做这个项目,需要调度者。但是当调度者决定哪个厂搞了后,需要告诉秘书部,秘书部存档进资料库后再告诉某个厂——Scheduler
  7. 当决定后,秘书部需要告诉厂长——kubelet
  8. 当有领导视察的时候,不知道飞机项目在哪个厂,则需要问门卫(门卫消息互通,问一个即可)——kube-proxy
  9. 跟外部合作时,是外联部——Cloud controller manager
    在这里插入图片描述

3. 工作演示

  • 当厂长kubelet发现厂里有飞机项目做不下去了之后,就会发现并上报给秘书api-server,
  • 秘书api-server再通报给决策者controller-manager说西厂的飞机项目搞不定了,
  • 决策者说给别的厂搞把,于是告诉秘书,秘书再把决策存入数据库etcd,秘书再将决策通知调度者scheduler。
  • 调度者随后动态地计算其他厂哪些适合搞飞机项目,其方案也会存入数据库etcd。
  • 东厂每天都会和秘书通电话,当知道决策之后就会开始在东厂开始飞机项目

在这里插入图片描述

  • 当整个项目搞起来,别人要访问则需要门卫大爷kube-proxy。
  • 门卫大爷则负责接受传达消息。当其他项目如造船项目应用1需要参观造车项目应用3的时候,则去找门卫大爷,门卫大爷再告诉他应用三是在哪里。
  • 故门卫大爷是打通整个网络访问的,谁想要访问、去哪访问
    在这里插入图片描述
  • 需要说明的是,整个集团架构,master总部其实是一个傀儡,真正决定的是程序员kubectl——挟天子以令诸侯
    在这里插入图片描述


---------------------
作者:别出BUG求求了
来源:CSDN
原文:https://blog.csdn.net/weixin_39589455/article/details/124459859
版权声明:本文为作者原创文章,转载请附上博文链接!
内容解析By:CSDN,CNBLOG博客文章一键转载插件

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

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

相关文章

程序员双手飞快敲键盘的时候是在敲代码吗?

当你看到一个程序员的两只手在键盘上上下翻飞,行云流水的时候,多半不是在敲击代码大概率是在跟产品经理撕逼讨论需求另一种可能就是在跟测试打口水仗10%几率是在论坛码字摸鱼或者和人家开喷了。1%几率是在跟MM聊天可以手速飞快而不需要停下思考的代码&am…

几分钟上线一个网站 真是神器

1、ToolJet 简介 ToolJet 是一个开源的低代码框架,可以快速构建和部署内部工具,而无需工程团队付出太多努力。您可以连接到您的数据源,例如数据库(如 PostgreSQL、MongoDB、Elasticsearch 等)、API 端点(To…

移植Python3到TQ2440(一)

平台 硬件:TQ2440 64MB内存 256MB NandFlashbootloader:U-Boot 2015.04kernel:linux-4.9Python: Python-3.6.0工具链:arm-none-linux-gnueabi-gcc 4.8.3概述 现在树莓派很火,在树莓派上面用户可以通过Python来控制板…

WinForm(六)组合布局属性

WinForm是基于控件的,不像codemark的架构,可以非常灵活的用mark来布局,它只能用控件布局属性和窗口控件来完成对UI的布局。容器控件有一组控件叫容器控件,对布局特别有作用,它们分别是:TableLayoutPanel&am…

Qt 网络编程

QT 网络编程 TCP 编程 模块引入 QT network 头文件 #include <QTcpServer> // TCP服务器端使用 #include <QTcpSocket> // TCP服务器和客户端都使用 编程流程 服务端 1&#xff09;实例化 QTcpServer 对象 -----------------------------> socket 2&#x…

日利率

2019独角兽企业重金招聘Python工程师标准>>> 利率计算 转载于:https://my.oschina.net/u/3342652/blog/1649028

Kafka 安装详解

注意&#xff1a;确保有JDK1.8版本及以上 官方文档&#xff1a;https://kafka.apache.org/quickstart 清华镜像下载&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/apache/kafka/ 首先下载安装包&#xff0c;在linux及Windows都可以使用。 1. Centos 安装部署 1.1 下载 将下…

【Maui正式版】创建可跨平台的Maui程序,以及有关依赖注入、MVVM双向绑定的实现和演示...

前言&#xff1a;Maui终于在2022年8月9日推送出来了。今儿就迫不及待来把玩一下先。A、我本地已有VS2022&#xff0c;不过版本比较老&#xff0c;此处选择更新。工具 -> 获取功能和更新里面&#xff0c;可以获取到新版本更新。B、最新版本是17.3.0&#xff0c;我本地只有17.…

WebSQL存储

2019独角兽企业重金招聘Python工程师标准>>> WebSQL这种存储技术&#xff0c;相对于学过数据库的人来说&#xff0c;还是比较容易理解和上手的&#xff0c;主要就是它的存储风格和我们一般所学的SQL Server 和Oracle比较像&#xff0c;对于HTML5来说&#xff0c;当然…

抖音服务器带宽有多大,才能供上亿人同时刷?

最近看到一个有意思的提问&#xff1a;抖音服务器带宽有多大&#xff0c;为什么能够供那么多人同时刷&#xff1f;今天来给小伙伴们科普一下。 抖音&#xff0c;百度&#xff0c;阿里云&#xff0c;腾讯都是自建的数据中心&#xff0c;都是 T 级别出口带宽&#xff08;总出口带…

ASP.NET Core 5.0中的Host.CreateDefaultBuilder执行过程

通过Rider调试的方式看了下ASP.NET Core 5.0的Web API默认项目&#xff0c;重点关注Host.CreateDefaultBuilder(args)中的执行过程&#xff0c;主要包括主机配置、应用程序配置、日志配置和依赖注入配置这4个部分。由于水平和篇幅有限&#xff0c;先整体理解、建立框架&#xf…

404和302

为什么80%的码农都做不了架构师&#xff1f;>>> 404 php中用header()函数是可以为返回页面添加404的头信息的&#xff0c;从而提示浏览器该网页找不到了。 所以可以使用&#xff1a;header("HTTP/1.0 404 Not Found");或者&#xff1a;header("Stat…

oracle sqlplus使用

2019独角兽企业重金招聘Python工程师标准>>> 1、常用连接方式 sqlplus / as sysdba 无需数据库进入可用状态&#xff0c;就可用用该命令登录&#xff0c;运行startup来启动。 sqlplus username/pwdhost/service_name&#xff0c;如&#xff1a; sqlplus tiger/scott…

20款IDEA 神级插件 效率提升 30 倍,写代码必备

插件目录 1. Alibaba Java Coding Guidelines 2.GsonFormat 3.A8Translation 4.Maven Helper 5.Free Mybatis plugin 6.Grep Console 7.Lombok 8.Nyan progress bar 9.FindBugs-IDEA 10.Key Promoter X 11.JavaDoc 12.ignore 13.RainbowBrackets 14.Activate-power-mode 15.C…

【温故知新】C# Linq中 Where使用技巧

微信公众号&#xff1a;趣编程ACE关注可了解更多的.NET日常实战开发技巧&#xff0c;如需源码 后台回复 源码 即可;如果觉得对你有帮助&#xff0c;欢迎关注C# Linq中 Where使用技巧hello 大家好&#xff0c;很开心又能重新分享C#编程开发技巧了&#xff0c;之前因为工作和生活…

分布式id解决方案

文章目录 1.分布式id实现方案 1.1.uuid1.2 数据库主键自增1.3 Redis自增1.4 号段模式1.5 雪花算法&#xff08;snowflake&#xff09; 1.5.1 百度&#xff08;uid-generator&#xff09;1.5.2 美团&#xff08;Leaf&#xff09;所谓id就是能够用作唯一标识的记号。 在我们日常的…

我和大象的十年往事 - 感恩、感谢、加油、腾飞

背景 http://www.idcquan.com/Special/OSCAR2018/index.html 由中国信息通信研究院主办、中国通信标准化协会支持的"OSCAR云计算开源产业大会"于2018年3月21日&#xff0d;22日在国家会议中心举行。 非常有幸获得了“OSCAR尖峰开源人物”奖项。 奖项不敢自居&#xf…

4种分布式session解决方案

cookie和session的区别和联系 cookie是本地客户端用来存储少量数据信息的&#xff0c;保存在客户端&#xff0c;用户能够很容易的获取&#xff0c;安全性不高&#xff0c;存储的数据量小 session是服务器用来存储部分数据信息&#xff0c;保存在服务器&#xff0c;用户不容易获…

Blazor University (43)JavaScript 互操作 —— 类型安全

原文链接&#xff1a;https://blazor-university.com/javascript-interop/calling-dotnet-from-javascript/type-safety/类型安全在从 JavaScript 调用 .NET[1] 部分中&#xff0c;您可能已经注意到我们的 JavaScript 的第 6 行在将随机生成的数字传递给 .NET 之前调用了 toStr…

分享 60 个神级 VS Code 插件

文章来源&#xff1a;juejin.cn/post/6994327298740600839 本文不做任何编辑器的比较&#xff0c;只是我本人日常使用 vscode 进行开发&#xff0c;并且比较喜欢折腾 vscode &#xff0c;会到处找这一些好玩的插件&#xff0c;于是越攒越多&#xff0c;今天给大家推荐一下我收…