为啥要使用docker?
微服务虽然具备各种各样的优势,但服务的拆分通用给部署带来了很大的麻烦
- 分布式系统中,依赖的组件非常多,不同组件之间部署时往往会产生一些冲突。
- 在数百上千台服务中重复部署,环境不一定一致,会遇到各种问题。
例如:一个项目中,部署时需要依赖于node,s、Redis、RabbitMQ、MySQL等,这些服务部署时所需要的函数库、依赖项各不相同,甚至会有冲突。给部署带来了极大的困难。
docker如何解决依赖的兼容性问题的?
- 将应用的Libs(函数库),Dep(依赖),配置与应用一起打包。
- 将每一个应用放在一个隔离容器(沙箱机制)去运行,避免相互干扰。
这样打包好的应用包中,既包含应用本身,也保护应用所需要的Libs、Deps,无需再操作系统上安装这些,自然就不存在不同应用之间的兼容问题了。
虽然解决了不同应用的兼容问题,但是开发、测试等环境会存在差异,操作系统版本也会有差异,怎么解决这些问题呢?
docker解决操作系统环境差异?
要解决不同操作系统环境差异问题,必须先了解操作系统结构。以一个Ubunu操作系统为例,
结构如下:
结构包括:
计算机硬件:例如CPU、内存、磁盘等。
系统内核::所有Linux发行版的内核都是Linux,例CentOs、Ubuntu、Fedora等。内核可以与计算机硬件交互,对外提供内核指令,用于操作计算机硬件。
系统应用:操作系统本身提供的应用、函数库。这些函数库是对内核指令的封装,使用更加方便。
应用于计算机交互的流程如下:
实现各种功能
- 应用调用操作系统应用 (函数库)。
- 系统函数库是对内核指今集的封装,会调用内核指令 。
- 内核指令操作计算机硬件。
此时,如果将一个Ubuntu版本的MySQL应用安装到CentOS系统,MySQL在调用Ubuntu函数库时,会发现找不到或者不匹配,就会报错了。