Docker 学习
- Docker概述
- Docker安装
- Docker命令
- 镜像命令
- 容器命令
- 操作命令
- Docker镜像
- Docker数据卷
- DockerFile
- Docker网络原理
- IDEA整合Docker
- Docker Compose
- Docker Swarm
- CI/CD Jenkins
Docker概述
Docker的基本组成
镜像(image):
- docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,
tomcat镜像—》run—》tomcat01容器(提供服务器)
- 通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)
容器(container):
- Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。
- 启动、停止、删除
- 目前把容器理解为一个简易的linux系统
仓库(repository):
- 仓库就是存放镜像的地方!
- 仓库分为共有仓库和私有仓库
- Docker Hub(默认是国外的),要想用国内的,阿里云。。。都有容器服务器,(需要配置镜像加速)
Docker为什么出现?
一款产品:开发——上线 两套环境! 应用环境,应用配置!
开发 — 运维。问题:我在我的电脑上可以运行!版本更新,导致服务不可用!对于运维来说,考验就很大
环境配置是十分麻烦的,每一个机器都要部署环境(集群Redis,ES,Hadoop…)!费时费力。
发布一个项目(jar + (Redis MySQL jdk ES)),项目能不能带上环境安装打包!
之前在服务器配置一个应用的环境 Redis MySQL jdk ES Hadoop ,配置超麻烦了,不能够跨平台。
Windows,最后发布到Linux
传统:开发jar,部署运维来做!
现在:开发打包部署上线,一套流程做完!
java — apk – 发布 (应用商店) ---- 张三使用apk — 安装即可用
java — jar(环境)— 打包项目带上环境(镜像)----(Docker仓库:商店)— 下载我们发布的镜像,直接运行
Docker给以上的问题,提出了解决方案!
Docker的思想就来自于集装箱!
JRE – 多个应用(端口冲突)— 原来都是交叉的
隔离:Docker核心思想!打包装箱!每个箱子是相互隔离的。
Docker通过隔离机制,可以将服务器利用到极致。
Docker能干什么
之前的虚拟机技术的缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢!
容器化技术
容器化技术不是模拟的一个完整的操作系统
比较Docker和虚拟机的不同
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
- 容器内的应用直接运行在 宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了,
- 每个容器间是互相隔离的,每个容器内都有一个属于自己的文件系统,互不影响。
DevOps ( 开发、运维 )
更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker:打包镜像测试,一键运行
更便捷的升级和扩缩容
使用了Docker之后,我们部署应用和搭积木一样!
项目打包为一个镜像
更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的。
更高效的计算资源利用:
Docker是内核级别的虚拟化,集群,可以在一个物理机上可以运行很多的容器实例,服务器性能可以被压榨到极致。