Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别?
理解引发开发,测试与运维不和谐的原因是什么?(环境不同)理解运维对架构师的抱怨点在哪里?(希望可以一键部署)了解学习过程中集群搭建所面临的问题是什么?(虚拟机不能启动过多)能供描述什么是DevOps?(一种思想,一种管理模式,用于促进三部门间的沟通与协作)能够简述的由来(container这个单词不仅有容器的意思,还有集装箱,这就是为什么LOGO中出现很多集装箱的原因,至于鲸鱼实在众多LOGO方案
1.3.1 提供统一的运行环境
在生产环境中,很多时候的开发,测试及上线环境都是不一样的,从而导致项目(war
或者jar
)在不同的阶段出现很多其他阶段所不存在的奇怪的问题。
Docker
容器除了可以提供相同的应用外,还提供了该应用的统一运行环境,确保在任何宿主机HOST
上都可以跑出相同的结果,即Docker = jar/war+
环境。
名称解释:
宿主机:容器想要运行就需要有个机器,这个机器就是宿主机。
1.3.2 便捷的应用迁移
由于Docker
确保了统一运行环境,使得应用的迁移更加便捷,无论是物理机,虚拟机,公有云,私有云,Docker
镜像的运行结果都是相同的,用户可以很方便的将一个平台上运行的应用迁移到另一个平台上,而无需担心运行环境的变化导致应用无法正常运行。
1.3.3 超快的启动时间及更简单的管理
传统的虚拟机技术启动应用一般需要数分钟,首先要启动虚拟机,然后在加载虚拟机操作系统,最后还需要再手工启动应用。而Docker
容器应用,由于直接进行宿主机中,无需启动操作系统,因此可以做到秒级,甚至毫秒级的启动。
使用Docker
只需要小小的修改,就可以替代以往大量的更新工作,所有的修改都已增量的方式被分发和更新,从而实现自动化并且高效的管理。
1.3.4更轻松地维护和扩展
Docker
公司及各个开源项目团队一起维护了一大批高质量的官方镜像,即可以直接在生产环境使用,又可以作为基础进一步定制,大大的降低了应用服务的镜像制作成本。
Docker
使用的分成存储及镜像的技术,使得应用重复部分的复用更为容易,也使得应用的维护更新更加简单,基于基础镜像进一步扩展镜像也变得非常简单。
1.4 容器与虚拟机的区别
Docker
容器的本质就是通过容器虚拟技术虚拟出的一台主机,就像虚拟机一样,可以将应用及其运行环境部署在这台虚拟出的主机上运行,但是容器与虚拟机又有着本质的不同。
1.4.2传统虚拟技术
传统的虚拟技术是在物理机的操作系统之上安装一个虚拟机管理程序,例如VMware,VirtualBox
等,在其管理下可以创建很多个虚拟机,每个虚拟机需要安装自己独立的操作系统,而应用就是安装在虚拟机操作系统之上的应用程序,应用程序通过调用各种命令或库函数来使用其需要的各种系统资源。
对于玩全相同的两个应用,其若需要运行在两个虚拟机中,则就需要两套完全相同或的虚拟机操作系统与bins/libs
,存在大量的资源占用冗余,形成资源浪费。
1.4.3容器虚拟化技术
Docker
容器运行在Docker
引擎之上,所有Docker
共享同一个Docker
引擎,但它们有时相互隔离,互补干扰的,由于Docker
容器不需要进行虚拟硬件及操作系统,而是共享宿主机的硬件与操作系统,所以Docker
容器对系统资源的占用很少,其仅包含运行时必须的一些资源。所有Docker
容器对于系统资源的使用都是由Docker
引擎统一进行管理,所以对系统资源的利用率很高,无论是应用执行速度,内存损耗或者文件存储速度都要比传统虚拟机技术更高效。
1.4.4普通系统中的程序运行原理
程序:程序是一个对计算机硬件资源调度使用的指令序列。
1.4.5容器系统中的程序运行原理
Docker
容器运行在Docker
引擎之上,所有Docker
容器共享同一个Docker
引擎,但他们的运行又是相互隔离,又互不干扰,由于docker
容器不需要进行虚拟硬件及操作系统,而是共享的宿主主机的硬件与操作系统,所以Docker
容器对系统资源占用较少,其仅包含运行时必须的一些资源,所有Docker
容器对于系统资源的使用都是由docker
引擎统一进行管理,所以对系统的资源的利用率很高,无论是应用执行速度,内存损耗或者文件存储速度都要比传统虚拟机技术更高效。
1.5 Window系统的虚拟化
1.5.1 Hypervisor
Hypervisor
——一种运行在基础物理服务器和操作系统之间的中间件层,可允许多个操作系统和应用共享硬件,也可以叫做VMM
,即虚拟机监视器。
Hypervisor
是一种在虚拟环境中的"元"操作系统,他们可以访问服务器上包括磁盘和内存在内的所有物理设备,hypervisor
不但协调着这些硬件资源的访问,也同时在各个虚拟机之间施加防护,当服务器启动hypervisor
时,它会加载所有虚拟机客户端的操作系统同时会分配给没一台虚拟机适量的内存
,CPU
,网络
和磁盘
。
1.5.2 Hyper-V
hyper-V
是微软的一款虚拟化产品,是微软第一个采用类似Vmware ESX
和Citrux Xen
基于hypervisor
的技术,这也意味着微软会更加直接的与市场先行者VMware
展开竞争,但竞争的方式会有所不同。
Hyper-V
是微软提供的商业化的Hypervisor
,KVM
与XEN
都是linux
系统之上的开源的Hypervisor
。
1.5.3 现在的Windows系统
现在Windows
系统并不是一个“纯洁”的windows
了,而是运行在Hyoer-V
上的虚拟机。而原来的应用层现在也是一个运行在Hyper-V
上的虚拟机,系统上运行的一个个的应用其实就是运行在应用层虚拟机之中。操作系统虚拟机能够管理应用层虚拟机。
1.5.4 Windows系统的启动过程
1.5.5 Vmware与windows系统
VMware
采用的是VMM
虚拟化技术,该技术要求直接访问CPU
硬件的虚拟化功能,但VMware
作为windows
系统中的应用是运行在应用层虚拟中的,导致VMware
无法直接访问CPU
硬件虚拟化功能,所以安装Vmware Workstation
时会出现VMware Workstation
与Hyper-V
不兼容的问题。
从VMware Workstation15.5.5版本
开始,VMware
重构了WMM
技术,使其不需要直接访问CPU
硬件,而是通过windows10
系统的WHP
的API
来运行。
结论:我们在安装Vmware Workstation
时,要安装15.5.5
版本或更高版本,而Windows
系统也要使用Windows10
或者更高版本。
1.6 Docker系统架构
Docker
中具有几个非常重要的概念,通过理解概念来了解Docker
的系统架构。
Docker Daemon
即Dockerd
,docker
守护进程, 其监听者Docker API
请求并管理Docker
对象,例如镜像,容器,网络和卷,守护进程还可以与其他守护进程通信以管理Docker服务。
1.6.2 镜像Image
Docker
镜像是用于创建Docker
容器的模板,就像面向对象编程中的类
1.6.2 镜像Image
Docker
容器是镜像运行时的实体,就像面向对象编程中类的实体,一个类可以创建N多个实体,那么一个镜像同样也可以创建出N多个容器,每个处于运行状态的容器中都饱含着一个或多个相关的应用,且它的运行不会干扰到其他容器,因为它们之间是相互隔离的。
1.6.3 仓库Repository
Docker
镜像仓库用于保存相关的一组镜像,这组镜像具有相同的镜像名称,都与镜像仓库名称相同,仓库根据其中的镜像是否可以被公开共享,可以分为公开库与私有库。
1.6.4 标签Tag
通过<repository><tah>
即可唯一定位一个镜像,即镜像标签其实就是镜像仓库中用于区分各个镜像的一种标识,同一仓库中的镜像具有不同的标签。
1.6.6 镜像中心Registry
Docker
的镜像中心存放着很多由官方,其他机构或个人创建的Docker
仓库,Docker
用户可以直接从这些仓库中pull
需要的镜像,也可以将自己制作的镜像push
到Docker
镜像中心相应的仓库中,最常用的镜像中心是Docker
官方的Docker Hub(https://hub.docker.com
)
1.7 总结:
1.7.1 docker引入
理解引发开发,测试与运维不和谐的原因是什么?(环境不同)
理解运维对架构师的抱怨点在哪里?(希望可以一键部署)
了解学习过程中集群搭建所面临的问题是什么?(虚拟机不能启动过多)
能供描述什么是DevOps
?(一种思想,一种管理模式,用于促进三部门间的沟通与协作)
1.7.2 Docker简介
能够简述Docker LOGO
的由来(container
这个单词不仅有容器的意思,还有集装箱,这就是为什么LOGO
中出现很多集装箱的原因,至于鲸鱼实在众多LOGO
方案中由网友投票得出的结果),Docker
名称的含义,(Docker
的本义为码头工人,即操作集装箱的人)
1.7.3 Docker的用途
了解Docker
可以将应用与环境打包为镜像,然后实现“一处可运行,处处可运行”
1.7.4 容易与虚拟机的区别
容器与虚拟机的最大区别是,虚拟机中存在独立的硬件系统与操作系统,但是容器中的全都是宿主机的操作系统与硬件系统。
1.7.5 Windows系统的虚拟化
最全的Linux教程,Linux从入门到精通
======================
-
linux从入门到精通(第2版)
-
Linux系统移植
-
Linux驱动开发入门与实战
-
LINUX 系统移植 第2版
-
Linux开源网络全栈详解 从DPDK到OpenFlow
第一份《Linux从入门到精通》466页
====================
内容简介
====
本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。
本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。
需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论
更多推荐
所有评论(0)