黑马笔记
为什么要使用Docker?
项目部署问题:
大型项目组件较多,运行环境也较为复杂,部署时会碰到一些问题:
1.依赖关系复杂,容易出现兼容性问题
2.开发、测试、生产环境有差异
甚至这些环境他们的Linux操作系统不同(Centos,Ubuntu),在一个环境配好的东西,在另一个系统环境下可能就不能正常运行了
Docker如何解决依赖的兼容问题的?
将应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包
将每一个应用放到一个隔离容器去运行,避免相互干扰
但是这只是解决了混乱依赖的问题,有了Docker,依赖不用去管理的,但是仅限于同一个操作系统。因为在打包某一个应用时,是需要基于某种操作系统去打包的。(如Ubuntu上打包的应用,在Centos上是不能够运行的)
所以,不同环境的操作系统,Docker如何解决?先了解Linux操作系统的结构:
内核与硬件交互,提供操作硬件的指令
指令大多比较简陋,如果基于指令开发应用,那会相当麻烦,所以就有了系统应用。
系统应用封装内核指令为函数,便于程序员调用
程序员可以基于这些函数库进行开发,程序调用函数库,函数库调用内核指令,指令再调用计算机硬件。
Ubuntu和Centos都是基于Linux内核的,只是系统应用不同,提供的函数库有差异
Docker如何解决不同系统环境问题?
Docker将用户程序与所需要调用的系统(比如Ubuntu)函数库一起打包
Docker运行到不同操作系统时,直接基于打包的库函数,借助于操作系统的Linux内核来运行
总结:
Docker是一个快速交付应用、运行应用的技术:
1.可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操作系统
2.运行时利用沙箱机制形成隔离容器,各个应用互不干扰
3.启动、移除都可以通过一行命令完成,方便快捷(因为这种完整的程序包,在运行时已经包含了自己所需要的一切,所以快捷)
镜像和容器
镜像(Image):Docker将应用程序及其所需的依赖、函数库、环境、配置等文件打包在一起,称为镜像。(镜像就是硬盘中的文件,上图mysql的文件)
容器:镜像中的应用程序运行后形成的进程就是容器,只是Docker会给容器做隔离,对外不可见。(可以理解为,把Mysql这个应用跑起来,形成的进程就是容器)
1.镜像是只读的,也就是说容器在运行过程中,不能往镜像里写东西,可以基于镜像去创建容器,容器可以从镜像中读取数据。
2.mysql容器在创建的时候,会拷贝一份镜像中的数据,需要执行写操作的时候,只写到自己的空间里,这就是隔离的特性,不会对其他容器和镜像产生影响。
只有这样镜像才不会被创建的容器所干扰
怎么把镜像共享给别人去使用呢?
DockerHub:是一个Docker镜像的托管平台。这样的平台称为Docker Registry。
国内也有类似于DockerHub的公开服务,比如网易云镜像服务,阿里云镜像库。
上面是共享的方案,那么怎么利用Docker完成镜像构建,或者从远端拉取镜像呢,怎么运行容器呢?
Docker架构:
Docker是一个CS架构的程序,由两部分组成:
服务端(Server):Docker守护进程,负责处理Docker指令,管理镜像,容器等(不管是构建镜像,远端拉取镜像还是运行镜像,都是由服务端来完成)。
客户端(Client):通过命令或RestAPI向Docker服务端发送指令。可以在本地或远程向服务端发送指令。
docker build:该命令到达Docker Server之后,会被守护进程接收和处理,它会利用你提供的数据构建出一个镜像(如图中的Nginx镜像) 。
docker pull:该命令发送到Docker Server端,守护进程就会去Registry拉取你指定的镜像(Registry中会有官方提供的优质镜像(如图拉取下来的Redis镜像))。
docker run:该命令会告诉Server要去创建容器,守护进程接收到命令之后,就会帮助你完成容器的创建。