Docker与K8s关系介绍不会Docker也可以使用K8s


Posted in Servers onJune 25, 2022

K8s和Docker 的关系

Docker 和 K8s 这两个经常一起出现,两者的Logo 看着也有一定联系一个是背上驮着集装箱的鲸鱼一个是船的舵轮。

Docker与K8s关系介绍不会Docker也可以使用K8s

不过两者不能放在一个维度上讨论,Docker 是当前流行的 Linux 容器解决方案,利用 Namespaces 、Cgroups 以及联合文件系统UnionFS 实现了同一主机上容器进程间的相互隔离。

Docker与K8s关系介绍不会Docker也可以使用K8s

  • NameSpaces:隔离进程,让进程只能访问到本命名空间里的挂载目录、PID、NetWork 等资源
  • Cgroups: 限制进程能使用的计算机系统各项资源的上限,包括 CPU、内存、磁盘、网络带宽等等
  • 联合文件系统UnionFS : 保存一个操作系统的所有文件和目录,在它基础之上添加应用运行依赖的文件。创建容器进程的时候给进程指定Mount Namespace 把镜像文件挂载到容器里,用 chroot 把进程的 Root目录切换到挂载的目录里,从而让容器进程各自拥有独立的操作系统目录。

而 K8s 是拥有容器编排能力的集群管理解决方案,可以按照应用的定义调度各个运行着应用组件 Docker 容器,但是 Docker 并不是 K8s 对容器的唯一选择,K8s 的 容器运行时支持对接多种容器 ,比如CoreOS公司的Rkt容器(之前称为Rocket,现更名为Rkt),Apache 开源的 Mesos 容器等。只要容器实现了 K8s 容器运行时的接口约定,都能让 K8s 进行调度。

Docker与K8s关系介绍不会Docker也可以使用K8s

Docker 公司也推出过自己的容器集群管理方案 Docker Swarm ,跟 K8s 算是竞品,但是在生产上几乎没人使用。

Docker Swarm 没有流行起来的深层次的原因就不深究了,从一些IT媒体的报道看,可能的原因是

  • 跟 Docker 深度绑定,人天生对集权主义非常反感。
  • Docker 公司在大规模集群管理上的经验不足,不像谷歌那样能高屋建瓴地给出好的解决方法。

容器用Docker,需要学到什么程度

看完 K8s 和 Docker 的关系后,我们已经有答案了,想学 K8s 不一定非得会 Docker。但是毕竟 Docker 还是目前最流行的 Linux 容器方案,绝大部分情况下我们还是会选择使用 Docker,那么我们 Docker 掌握到什么程度更易于我们学习 K8s 呢?

这个主要看我们想学会 K8s 干什么,即使运行在 K8s 之上的容器选择 Docker,如果我们是搭建一些基建类的软件,比如 MySQL、Redis之类的,因为这些组织已经提供了软件容器的镜像,我的使用体验是,完全用不到那些 Docker 的各种命令。

比如要在 K8s 集群上运行一个 MySQL 应用,写好应用的清单文件(就是各种配置和期望的状态),然后直接运行

kubectl apply -f mysql.yaml 

就好,K8s 的容器运行时会根据清单文件里的镜像名,帮我们调 Docker 的接口去下载镜像、运行容器。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
spec:
  selector:
    matchLabels:
      app: mysql
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
        - image: mysql:5.7
          name: mysql
          env:
            - name: MYSQL_ROOT_PASSWORD
              value: superpass
          ports:
            - containerPort: 3306
              name: mysql
          volumeMounts:
            - name: mysql-persistent-storage
              mountPath: /var/lib/mysql
            - name: mysql-config
              mountPath: /etc/mysql/conf.d/my.cnf
              subPath: my.cnf

上面配置文件,有删减。

不过,我们使用 K8s 除了搭建这种基础软件外,学 K8s 更多是让自己开发的服务能依托 K8s 集群管理、调度的能力变的更具鲁棒性、更portable。这个时候 Docker 方面的技能掌握基本的 Dockerfile 编写、打包上传镜像的命令。

学会这几个简单的Docker知识就完全够用,能支撑我们开始 K8s 的学习和练习啦,其他 Docker 相关的知识完全可以在做 K8s 练习时遇到问题、解决问题的过程中再学。

总结

这篇文章把 Docker 和 K8s 的关系给大家做了一个解答,希望还在迟疑自己现有的知识储备能不能直接学 K8s 的,赶紧行动起来,K8s 是典型的入门有点难,后面越用越香。

更多关于Docker与K8s关系的资料请关注三水点靠木其它相关文章!


Tags in this post...

Servers 相关文章推荐
win10安装配置nginx的过程
Mar 31 Servers
Nginx配置80端口访问8080及项目名地址方法解析
Mar 31 Servers
详解Apache SkyWalking 告警配置指南
Apr 22 Servers
nginx配置虚拟主机的详细步骤
Jul 21 Servers
使用Nginx搭载rtmp直播服务器的方法
Oct 16 Servers
Apache Linkis 中间件架构及快速安装步骤
Mar 16 Servers
Nginx禁止ip访问或非法域名访问
Apr 07 Servers
如何Tomcat中使用ipv6地址
May 06 Servers
Nginx利用Logrotate实现日志分割
May 20 Servers
nginx 配置指令之location使用详解
May 25 Servers
Windows server 2022创建创建林、域树、子域的步骤
Jun 25 Servers
Windows Server 修改远程桌面端口的实现
Windows server 2012 NTP时间同步的实现
windows server 2016 域环境搭建的方法步骤(图文)
Windows server 2022创建创建林、域树、子域的步骤
Windows Server 2022 超融合部署(图文教程)
win server2012 r2服务器共享文件夹如何设置
服务器SVN搭建图文安装过程
Jun 21 #Servers
You might like
封装一个PDO数据库操作类代码
2009/09/09 PHP
php Ubb代码编辑器函数代码
2012/07/05 PHP
PHP验证信用卡卡号是否正确函数
2015/05/27 PHP
PHP实现的同步推荐操作API接口案例分析
2016/11/30 PHP
解决extjs在firefox中关闭窗口再打开后iframe中js函数访问不到的问题
2008/11/06 Javascript
jQuery1.6 使用方法一
2011/11/23 Javascript
jquery js 重置表单 reset()具体实现代码
2013/08/05 Javascript
js判断运行jsp页面的浏览器类型以及版本示例
2013/10/30 Javascript
怎么选择Javascript框架(Javascript Framework)
2013/11/22 Javascript
Javascript Ajax异步读取RSS文档具体实现
2013/12/12 Javascript
js实现点击链接后窗口缩小并居中的方法
2015/03/02 Javascript
jQuery根据元素值删除数组元素的方法
2015/06/24 Javascript
JavaScript读二进制文件并用ajax传输二进制流的方法
2016/07/18 Javascript
Javascript设计模式之装饰者模式详解篇
2017/01/17 Javascript
JS检测是否可以访问公网服务器功能代码
2017/06/19 Javascript
js中事件对象和事件委托的介绍
2019/01/21 Javascript
详解如何实现Element树形控件Tree在懒加载模式下的动态更新
2019/04/25 Javascript
Layui 带多选框表格监听事件以及按钮自动点击写法实例
2019/09/02 Javascript
Python 除法小技巧
2008/09/06 Python
Python 变量类型及命名规则介绍
2013/06/08 Python
Python数据类型详解(二)列表
2016/05/08 Python
Python中音频处理库pydub的使用教程
2017/06/07 Python
python简单实现操作Mysql数据库
2018/01/29 Python
对python中类的继承与方法重写介绍
2019/01/20 Python
利用anaconda保证64位和32位的python共存
2021/03/09 Python
对python中不同模块(函数、类、变量)的调用详解
2019/07/16 Python
css3 伪类选择器快速复习小结
2019/09/10 HTML / CSS
解决CSS3 transition-delay 属性默认值0不带单位失效的问题
2020/10/29 HTML / CSS
美国女性奢华品牌精品店:INTERMIX
2017/10/12 全球购物
JAVA软件工程师测试题
2014/07/25 面试题
《长相思》听课反思
2014/04/10 职场文书
委托证明模板
2014/09/16 职场文书
早读课迟到检讨书
2014/09/25 职场文书
2015年世界急救日宣传活动方案
2015/05/06 职场文书
python数据分析之用sklearn预测糖尿病
2021/04/22 Python
Vue中foreach数组与js中遍历数组的写法说明
2021/06/05 Vue.js