一、Docker为什么会出现

  • 一款产品:开发👉上线 经常需要两套环境!需要对其进行部署应用环境和应用配置。那么就有了开发人员和运维人员
  • 问题:我在我的电脑上可以运行!但是在你的电脑就不能运行!或者版本更新,导致服务不可用!对于运维来说,考验就十分大,环境配置是十分的麻烦,每一个机器都要部署环境(集群Redis、ES、Hadoop)!费时费力。
  • 发布一个项目(jar+(Redis MySQL jdk ES)),项目能不能都带上环境安装打包!
  • Windows,最后发布到Linux:

    • 传统:开发jar,运维来做
    • 现在:开发打包部署上线,一套流程做完
  • java—apk—发布(应用商店)—张三使用apk—安装即可用

  • java—jar(环境)—打包项目带上环境(镜像)—(Docker仓库:商店)—下载我们发布的镜像—直接运行即可

  • Docker的思想就来自于集装箱

image.png

  • 隔离:Docker核心思想!打包装箱!每个箱子都是互相隔离的。利用隔离机制可以将服务器利用到极致!
  • 比如多个应用都是都是交叉的,可能会有端口冲突,如果使用了Docker就会隔离起来,不会造成端口冲突

  • 本质:所有的技术都是因为出现了一些问题,我们需要去解决,才去学习!

    二、Docker的历史

  • 2010年,几个搞IT的年轻人,就在美国成立了一家公司 dotCloud ,做一些paas的云计算服务!LXC(虚拟机)有关的容器技术!他们将自己的技术(容器化技术)命名就是Docker!

  • Docker刚刚诞生的时候,没有引起行业的注意。dotCloud就活不下去,于是提出了开源(开放源代码),2013年,Docker开源。越来越多人发现了Docker的优点,于是Docker火了,Docker每个月都会更新一个版本
  • 2014年4月9日,Docker1.0发布
  • Docker为什么这么火,因为它十分的轻巧。在容器技术出现之前,我们都是使用虚拟机技术,虚拟机也是虚拟化技术,Docker容器技术,也是一种虚拟化技术

    1. VMLinux Centos原生镜像(一个电脑!)隔离,需要开启多个虚拟机 几个G 几分钟
    2. Docker:隔离,镜像(最核心的环境 4m + jdk + mysql)十分的小巧,运行镜像就可以了!小巧!几个M KB 秒级启动
  • 到现在,所有开发人员都必须学会Docker!

  • Docker是基于Go语言开发的!开源项目!
  • 官网:https://www.docker.com/
  • 文档地址:https://docs.docker.com/ Docker的文档是超级详细的!
  • 仓库地址:https://hub.docker.com/

    三、Docker能做什么

    1、虚拟机技术

    image.png

  • 虚拟机技术缺点:

    • 1、资源占用十分多
    • 2、冗余步骤多
    • 3、启动很慢

      2、容器化技术

  • 容器化技术不是模拟的一个完整的操作系统

image.png

3、不同点

  • 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
  • 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了。
  • 每个容器是互相隔离的,每个容器内都有一个属于自己的文件系统,互不影响

    四、DevOps(开发、运维)

  • 应用更快速的交付和部署

    • 传统:一堆帮助文档,安装程序
    • Docker:打包镜像发布测试,一键运行
  • 更便捷的升级和扩缩容
    • 使用了Docker后,我们部署应用就和搭积木一样!
    • 项目打包为一个镜像,扩展 服务器A!服务器B
  • 更简单的系统运维
    • 在容器化之后,我们的开发和测试环境都是高度一致的
  • 更高效的计算资源利用
    • Docker是内核级别的虚拟化,可以在一个物理机上可以运行很多的容器示例!服务器的性能可以被利用到极致
    • 1核2G的服务器能运行很多服务!