Docker学习大纲
本笔记 由 B站狂神说java 视频获取
- Docker概述
- Docker安装
- Docker命令
- 镜像命令
- 容器命令
- 操作命令
- …
- Docker镜像!
- 容器数据卷!
- DockerFile
- Docker网络原理
- IDEA整合Docker
- Docker Compose
- Docker Swarm
- CI\CD jenkins
Docker概述
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的历史
聊聊Docker
Docker是基于Go语言开发的!开源项目!
文档地址: https://docs.docker.com/ Docker的文档是超级详细的
仓库地址 : https://hub.docker.com/
Docker能干吗
之前的虚拟机技术
虚拟机技术缺点:
1、资源占用十分多
2、冗余步骤多
3、启动很慢!
容器化技术
容器化技术不是模拟的一个完整的操作系统
比较Docker和虚拟机技术的不同:
- 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
- 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
- 每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统,互不影响。
DevOps (开发、运维)
应用更快速的交付和部署
传统:一堆帮助文档,安装程序
Docker :打包镜像发布测试,一键运行
更便捷的升级和扩缩容
使用了Docker之后,我们部署应用就和搭积木一样!
项目打包为一个镜像,扩展服务器A!服务器B
更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的。
更高效的计算资源利用∶
Docker是内核级别的虚拟化,可以再一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致。
Docker中的名词概念
镜像(image)
docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像===>run ===> tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)。
容器(container)
Docker利用容器技术,独立运行一个或者一个组应用,通过镜像来创建的。
启动,停止,删除,基本命令!
目前就可以把这个容器理解为就是一个简易的linux系统
仓库(repository)
仓库就是存放镜像的地方!
仓库分为公有仓库和私有仓库!
Docker Hub(默认是国外的)
阿里云…都有容器服务器(配置镜像加速!)