微服务框架
【SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】
SpringCloud微服务架构
文章目录
- 微服务框架
 - SpringCloud微服务架构
 - 9 初识 Docker
 - 9.1 什么是Docker
 - 9.1.1 项目部署的问题
 - 9.1.2 Docker
 - 9.1.3 总结
 
9 初识 Docker
9.1 什么是Docker
9.1.1 项目部署的问题
大型项目组件较多,运行环境也较为复杂,部署时会碰到一些问题:
- 依赖关系复杂,容易出现兼容性问题
 - 开发、测试、生产环境有差异
 

比如这些技术,将来可能都要部署到我们的服务器上,而且大多数服务器都采用Linux 操作系统
这些应用技术在安装到Linux 上之前,都要做一些准备,因为这些应用都会有自己需要的依赖和函数库

而且每一个应用需要的东西可能还会【一般都会】存在差异

也可能一样,但是版本不同,因此如此复杂的关系,很容易就产生“不兼容”的问题

而且不同的环境之前还有差异【炸了】
因此在以前,开发部署的效率非常的低
9.1.2 Docker
【Docker 是如何解决依赖的兼容问题的?】
- 将应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包
 - 将每个应用放到一个隔离容器去运行,避免互相干扰
 

但是,这样的操作仅限于同一个操作系统,因为我们在打包应用时,肯定会基于某个固定的操作系统去打包,
如果一个应用是 Ubuntu 版本的,那么它的依赖和函数库肯定也是Ubuntu 版本的,现在把这个程序打包好扔到Windows 上显然是不能运行的
【所以Docker 又怎么解决这个问题?】
不同环境的操作系统不同,Docker如何解决?先来了解下操作系统结构

其实所有的Linux 操作系统,它都可以分成下面的情况

内核与硬件交互,提供操作硬件的指令
系统应用封装内核指令为函数,便于程序员调用
用户程序基于系统函数库实现功能
【那么问题来了, 一个Ubuntu 系统的应用为什么不能在 Windows 系统上运行呢?】

Ubuntu和CentOS都是基于Linux内核,只是系统应用不同,提供的函数库有差异
现在我有一个Ubuntu 和 一个CentOS

现在我们把Ubuntu 上的例如MySQL 应用尝试迁移到CentOS 上运行

如果函数库不存在,那就报错了【这就是应用不能跨系统调用的原因】
【那么针对这样的问题,Docker 如何解决?】
Docker如何解决不同系统环境的问题?
- Docker将用户程序与所需要调用的系统(比如Ubuntu)函数库一起打包
 - Docker运行到不同操作系统时,直接基于打包的库函数,借助于操作系统的Linux内核来运行
 

【这样就不受系统应用使用的操作系统类型影响了】
u1s1 ,这PPT 做得真漂亮

【Docker如何解决大型项目依赖关系复杂,不同组件依赖的兼容性问题?】
- Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像
 - Docker应用运行在容器中,使用沙箱机制,相互隔离
 
【Docker如何解决开发、测试、生产环境有差异的问题】
- Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行
 
9.1.3 总结
Docker是一个快速交付应用、运行应用的技术:
-  
可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操作系统
 -  
运行时利用沙箱机制形成隔离容器,各个应用互不干扰
 -  
启动、移除都可以通过一行命令完成,方便快捷
 



















