本系列笔记参考于:
- docker 入门 —— 狂神说Java
- https://www.bilibili.com/video/BV1og4y1q7M4
感谢分享!
Docker概述
docker
英 [ˈdɒkə®] 美 [ˈdɑːkər]
码头工人
1、Docker 为什么出现?
一款产品: 开发–上线 两套环境!应用环境,应用配置!
开发 — 运维。 问题:我在我的电脑上可以允许!版本更新,导致服务不可用!对于运维来说考验十分大?
环境配置是十分的麻烦,每一个及其都要部署环境(集群Redis、ES、Hadoop…) !费事费力。
发布一个项目( jar + (Redis MySQL JDK ES) ),项目能不能带上环境安装打包!
之前在服务器配置一个应用的环境 Redis MySQL JDK ES Hadoop 配置超麻烦了,不能够跨平台。
开发环境Windows,最后发布到Linux!
传统:开发jar,运维来做!
现在:开发打包部署上线,一套流程做完!
安卓流程:java — apk —发布(应用商店)一 张三使用apk一安装即可用!
docker流程: java-jar(环境) — 打包项目帯上环境(镜像) — ( Docker仓库:商店)-----
Docker给以上的问题,提出了解决方案!
Docker的思想就来自于集装箱!
JRE – 多个应用(端口冲突) – 原来都是交叉的!
隔离:Docker核心思想!打包装箱!每个箱子是互相隔离的。
Docker通过隔离机制,可以将服务器利用到极致!
总结:
项目依赖于环境,环境配置比较麻烦;Docker 可以在打包项目时,附带上环境,让项目运行不再受到环境的制约
2、Docker 历史
2010年,几个年轻人,就在美国成立了一家公司 dotcloud,做一些pass的云计算服务!LXC(Linux Container容器)有关的容器技术!
Linux Container 容器是一种内核虚拟化技术,可以提供轻量级的虚拟化,以便隔离进程和资源。
他们将自己的技术(容器化技术)命名就是 Docker,Docker 刚刚延生的时候,没有引起行业的注意!dotCloud,就活不下去!
开源
2013年,Docker开源!
越来越多的人发现docker的优点!火了。Docker每个月都会更新一个版本!
2014年4月9日,Docker1.0发布!
docker为什么这么火?十分的轻巧!
在容器技术出来之前,我们都是使用虚拟机技术!
虚拟机:在window中装一个VMware,通过这个软件我们可以虚拟出来一台或者多台电脑!笨重!
虚拟机也属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!
- vm:linux centos 原生镜像(一个电脑!) 隔离、需要开启多个虚拟机! 几个G、几分钟
- docker:隔离,镜像(最核心的环境 4m + jdk + mysql)十分的小巧,运行镜像就可以了!小巧! 几个M、秒级启动!
聊聊Docker
- Docker基于Go语言开发的!开源项目!
- docker官网:https://www.docker.com/
- 文档:https://docs.docker.com/ Docker的文档是超级详细的!
- 仓库:https://hub.docker.com/
3、Docker 用途
1)之前的虚拟机技术
各个应用共享运行环境
虚拟机技术缺点:
- 资源占用十分多
- 冗余步骤多
- 启动很慢!
2)容器化技术
容器化技术不是模拟一个完整的操作系统;各个应用都有自已的运行环境,相互隔离
比较Docker和虚拟机技术的不同:
- 传统虚拟机,虚拟出一套硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件;笨重
- 容器内的应用直接运行在宿主机的内核,容器是没有自己的内核的,也没有虚拟的硬件,所以就轻便了
- 每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统(运行环境),互不影响
3)DevOps(开发、运维)
-
应用更快速的交付和部署
- 传统:一堆帮助文档,安装程序。
- Docker:打包镜像、发布测试、一键运行。
-
更便捷的升级和扩缩容
- 使用了 Docker之后,部署应用就和搭积木一样
- 项目打包为一个镜像,扩展服务器A!–> 服务器B
-
更简单的系统运维
- 在容器化之后,开发、测试环境都是高度一致的
-
更高效的计算资源利用
- Docker是内核级别的虚拟化,可以在一个物理机上运行很多的容器实例!服务器的性能可以被压榨到极致。