01 - Docker的概述、原理及能解决的问题

当下的问题

  • 开发、测试、生产等环境的不同可能导致应用程序运行的结果有所不同,甚至会出现错误:

    • 如:各环境中的JDK、Tomcat、MySQL等版本各有不同;
    • 在JDK1.6中写的代码可能在JDK1.8中已经Deprecated了;
    • 在JDK1.8中写的代码可能在JDK1.6中还不支持。
  • 需要在一个项目的多个版本中进行切换时很不方便,项目转移服务器时很不方便:

    • 如有一个博客,在1.0这个版本中不允许网友发博文,在2.0这个版本中允许网友发博文,在运行了2.0版本一段时间后需要切换到1.0时就相对较麻烦(除非在服务器上存有多个版本);
    • 当需要将此博客网站移到其他服务器是显得有些麻烦,特别是转移后还有可能需要在多个版本中切换使用,转移过程也可能会导致数据丢失或操作错误等问题。
  • 多人使用同一台服务器时的尴尬问题难以解决:

    • 多人使用同一服务器的问题最为严重,因为每个人的开发环境都有可能不同,各种服务工具的版本不统一问题、各种配置习惯不统一的问题等;
    • 在服务器运维过程中很难同时满足诸多开发者的不同需求;
    • 也很难在同一服务器上安装多个不同版本的JDK、Tomcat、MySQL等
  • ……

Docker概述

Docker的诞生可以很轻松的解决上述的各种问题,并且Docker的作用远不止这些。

先来看一下在Docker中的几个比较关键的组件:

  • 容器 - Docker运行的最小单位:
    • 每个容器都是一个轻量级的虚拟机;
    • 每个容器都拥有独立的root文件系统、网络服务、进程服务等
    • 容器与容器之间可以互不干扰,容器不会关心其他容器内部运行的是什么东西,所以通过容器可以让一台服务器内安装不同版本的JDK、Tomcat等(只要运行在不同的容器内部即可);
    • 一般一个容器只干一件事情,如:一个容器内只运行Tomcat,另一容器内只运行MySQL。
  • 镜像 - 用于产生容器:
    • 一个镜像可以产生很多容器;
    • 镜像可以在本地创建,创建成功后即可启动容器运行;
    • 可以将镜像推送(push)到Registry(仓库)中;
    • 可以将Registry(仓库)中的镜像拉取(pull)到本地。
  • Registry(仓库)- 用于存放镜像:
    • Registry可以是官方的,也可以是国内知名的(如阿里云的),也可以是私有的;
    • 由于仓库在远程,所以为应用程序的移植提供的便利。

Docker的原理及各个重要组件间的关系可以通过下图有所认识:

Docker几个重要组件的关系图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,716评论 15 147
  • 一、Docker 简介 Docker 两个主要部件:Docker: 开源的容器虚拟化平台Docker Hub: 用...
    R_X阅读 9,850评论 0 27
  • 转载自 http://blog.opskumu.com/docker.html 一、Docker 简介 Docke...
    极客圈阅读 13,588评论 0 120
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,861评论 19 139
  • 你满怀憧憬的描述着未来 我痴痴地望着你的脸 当八目相对的那一刻你笑我傻我说你呆
    乐四月阅读 1,301评论 1 3

友情链接更多精彩内容