Docker 学习

  • Docker概述
  • Docker安装
  • Docker命令
  • 镜像命令
  • 容器命令
  • 操作命令
  • Docker镜像
  • Docker数据卷
  • DockerFile
  • Docker网络原理
  • IDEA整合Docker
  • Docker Compose
  • Docker Swarm
  • CI/CD Jenkins

Docker概述

Docker的基本组成

docker容器ip_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是内核级别的虚拟化,集群,可以在一个物理机上可以运行很多的容器实例,服务器性能可以被压榨到极致。