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 相关文章推荐
nginx简单配置多个server的方法
Mar 31 Servers
nginx 多个location转发任意请求或访问静态资源文件的实现
Mar 31 Servers
详解Nginx 工作原理
Mar 31 Servers
nginx结合openssl实现https的方法
Jul 25 Servers
Nginx性能优化之Gzip压缩设置详解(最大程度提高页面打开速度)
Feb 12 Servers
关于Nginx中虚拟主机的一些冷门知识小结
Mar 03 Servers
阿里云 Windows server 2019 配置FTP
Apr 28 Servers
使用 Docker Compose 构建复杂的多容器App
Apr 30 Servers
云服务器部署 Web 项目的实现步骤
Jun 28 Servers
Docker部署Mysql8的实现步骤
Jul 07 Servers
Nginx代理Redis哨兵主从配置的实现
Jul 15 Servers
zabbix如何添加监控主机和自定义监控项
Aug 14 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
echo(),print(),print_r()之间的区别?
2006/11/19 PHP
PHP __autoload()方法真的影响性能吗?
2012/03/30 PHP
解析PHP 使用curl提交json格式数据
2013/06/29 PHP
Linux下手动编译安装PHP扩展的例子分享
2014/07/15 PHP
zend framework框架中url大小写问题解决方法
2014/08/19 PHP
PHP实现的浏览器检查类
2016/04/11 PHP
PHP实现对xml的增删改查操作案例分析
2017/05/19 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
PHP实现发送微博消息功能完整示例
2019/12/04 PHP
javascript(jquery)利用函数修改全局变量的代码
2009/11/02 Javascript
ASP.NET jQuery 实例12 通过使用jQuery validation插件简单实现用户注册页面验证功能
2012/02/03 Javascript
javascript实现复选框选中属性
2015/03/25 Javascript
js获取数组的最后一个元素
2015/04/14 Javascript
基于JavaScript实现表单密码的隐藏和显示出来
2016/03/02 Javascript
node.js从数据库获取数据
2016/05/08 Javascript
JS实现鼠标框选效果完整实例
2016/06/20 Javascript
jQuery自定义插件详解及实例代码
2016/12/29 Javascript
Vue中父组件向子组件通信的方法
2017/07/11 Javascript
解读vue生成的文件目录结构及说明
2017/11/27 Javascript
Vue项目报错:Uncaught SyntaxError: Unexpected token
2018/11/10 Javascript
JS前端知识点offset,scroll,client,冒泡,事件对象的应用整理总结
2019/06/27 Javascript
使用Python3编写抓取网页和只抓网页图片的脚本
2015/08/20 Python
Python HTML解析模块HTMLParser用法分析【爬虫工具】
2019/04/05 Python
打包python 加icon 去掉cmd黑窗口方法
2019/06/24 Python
Python图像处理库PIL的ImageFilter模块使用介绍
2020/02/26 Python
python openpyxl模块的使用详解
2021/02/25 Python
Python实现我的世界小游戏源代码
2021/03/02 Python
Maison Lab荷兰:名牌Outlet购物
2018/08/10 全球购物
英国婚礼商城:Wedding Mall
2019/11/02 全球购物
皇家阿尔伯特瓷器美国官网:Royal Albert美国
2020/02/16 全球购物
大学生毕业求职简历的自我评价
2013/10/24 职场文书
《山谷中的谜底》教学反思
2014/04/26 职场文书
护理专业毕业生自荐书
2014/05/24 职场文书
小学班主任心得体会
2016/01/07 职场文书
python 爬取华为应用市场评论
2021/05/29 Python
JavaScript执行机制详细介绍
2021/12/06 Javascript