谈到docker大家应该都不陌生,从2013年初诞生到现在,短短两年时间内,迅速成为仅次于openstack的最受欢迎的云计算开源项目。

那么是什么原因导致docker这么火热呢?

我也很感兴趣,因此我将用docker实践这一系列博文,记录我对docker的认识和实践。

本文主要介绍docker是什么,以及docker与传统虚拟化之间的区别等。

docker是什么?

docker,它是一个基于LXC(LinuX Container)的高级容器引擎,使用Go语言开发,遵循Apache2.0协议,全部开源代码均托管在github上(https://github.com/docker/docker)。它诞生于2013年初,最初发起者是dotCloud公司,该公司现已经改名为Docker Inc,专注于Docker相关技术和产品的开发。

目前,主流的linux、windows和mac都已经支持docker。需要注意的是,由于docker是基于LXC的,所以除了linux之外的操作系统,都是靠在虚拟机里面跑linux,再在linux上跑docker来实现的。

docker诞生的主要目标是"Build,Ship and Run Any App,Anywhere",即通过对应用组件的封装(Packaging)、分发(Deployment)、部署(Deployment)、运行(Runtime)等生命周期的管理,达到应用组件级别的"一次封装,到处运行"。这里的应用组件,既可以是一个web应用,也可以是一套数据库服务,甚至是一个操作系统或者编译器。

LXC是什么?

docker引擎的基础是Linux容器(linux container,LXC)技术。IBM DevelperWorks上给出了关于容器技术的准确描述:

容器有效地将单个操作系统管理的资源划分到孤立的组中,以便更好地在孤立的组之间平衡有冲突的资源使用需求。与虚拟化相比,这样既不需要指令级模拟,也不需要即时编译。容器可以在核心CPU本地运行指令,而不需要任何专门的解释机制。此外,也避免了准虚拟化(paravirtualization)和系统调用替换中的复杂性。

liunux容器并不是一个全新的概念,早期的容器技术有chroot、Solaris Containers、FreeBSD jail、linux-VServer、Solaris Zones、OpenVZ、lxc等。虽然这些技术发展很早,但是并没有集成到linux内核中去,使用起来很不方便,比如OpenVZ需要先给操作系统打上特定的内盒补丁才能使用。LXC项目借鉴了前人成熟的容器设计理念,并给予一系列新的内核特性实现了更具扩展性的虚拟化容器方案,并且被集成到了主流linux内核中,进而成为linux系统轻量级容器技术的事实标准。

在LXC的基础上,docker做了很大的改善,比如:

1、LXC的定位是作为一种虚拟机的替代方案。虽然所有的软件都可以安装在由 LXC 或者 Docker 管理的容器中,但是 Docker 更倾向于在一个容器中运行一个应用

2、每个LXC容器之间或许不兼容,但是 docker 采用了一种标准的配置方法使得由不同docker创建出的LXC能够完全兼容

3、Docker实现了类似 git 的容器版本管理方法,并且能够进行增量更新。

4、可以创建 base p_w_picpath 并将其保存在远程仓库 (repository) 中以便复用,其他容器可以在其基础上进行创建并保存为新的p_w_picpath。

5、docker提供了各种容器管理工具(如分发、版本、移植等)让用户无需关注底层的操作,可以简单明了地管理和使用容器

6、Docker管理着一个公共的 p_w_picpath 库方便用户分享自己的p_w_picpath,同时公司也可以构造自己私有的 p_w_picpath 库。

7、Docker的容器是根据 Dockerfile 构建的,你可以在构建 p_w_picpath 的过程中,根据需要运行任何命令和程序。

8、因为 docker 越来越流行,有大量的方法能够将其轻易地集成到开发过程中,比如可以采用统一的方法来构造用于持续集成的环境和开发环境的容器。

Docker与虚拟机的区别

其实,docker和虚拟机都是属于虚拟化技术。而虚拟化技术又分了很多种类。比如VM、KVM这种全虚拟化和早期的Xen这种半虚拟化。而docker则是属于操作系统级虚拟化。

像VM、KVM之类的虚拟出来的都是虚拟机,而docker作为一种轻量级的虚拟化方式,那么docker在运行应用上跟传统的虚拟机方式有哪些显著优势呢?

1、docker容器很快,启动和停止可以在秒级实现,这相比传统的虚拟机方式要快的很多

2、docker容器对系统资源需求很少,一台主机上可以同时运行数千个docker容器

3、docker通过类似git的操作来方便用户获取、分发和更新应用镜像,指令简明,学习成本很低

4、docker通过dockerfile配置文件来支持灵活的自动化创建和部署机制,提高工作效率

下面是docker容器技术和传统虚拟机技术的特性比较:

特性 容器 虚拟机
启动速度 秒级 分钟级
硬盘使用 一般为MB 一般为GB
性能 接近原生 弱于
系统支持量 单机支持上千个容器 一般几十个
隔离性 安全隔离 安全隔离

docker的这些优势是什么造成的呢?我们可以先看下图:

传统虚拟化是在硬件层面实现虚拟化,需要有额外的虚拟机管理应用和虚拟机操作系统层,而docker容器却不需要这两层,而是直接使用操作系统的系统调用接口。正因为这样子,docker容器除了运行其中的应用之外,基本不消耗额外的系统资源,保证应用性能的同时,尽量减小系统开销。传统虚拟机方式,运行N个不同的应用就要启动N个虚拟机(每个虚拟机需要单独分配内存、磁盘等资源),而docker只需要启动N个隔离的容器,并将应用放到容器中即可,这样子就减少了很多的资源消耗。

docker在软件开发流程中的优势

docker在设计之初就有以下几个目的:

1、加强开发人员写代码的开发环境和应用程序要部署的生产环境的一致性,从而降低那种"开发一切正常,肯定是运维的问题"的风险。

2、缩短代码从开发、测试到部署、上线运行的周期,让你的程序具备可以执行,易于构建、并易于协作

3、docker鼓励面向服务的架构和微服务架构。docker推荐单个容器运行一个应用程序或进程,这样就形成了一个分布式的应用程序模型

使用docker,开发人员只需要关心容器中运行的应用程序,而运维人员只需要关心如何管理容器。

总体来讲,docker在开发和运维过程中,具有如下优势:

1、更快速的交付和部署

2、更高效的资源利用。docker容器的运行不需要额外的虚拟机管理程序(VMM,以及Hypervisor)支持,它是内核级的虚拟化,可以实现更高的性能,同时对资源的需求很低

3、更轻松的迁移和扩展

4、更简单的更新管理。使用dockerfile,只需要小小的配置修改,就可以替代以往大量的更新工作,并且所有修改都以增量的方式进行分发和更新,从而实现自动化并且高效的容器管理。

OK!

转载于:https://blog.51cto.com/zouqingyun/1679507

Docker是个啥?相关推荐

  1. /var/lib/docker/overlay2/xxxxx no such file or directory docker文件删除引发的问题

    记一次误删引发的服务雪崩 K8s node节点磁盘报警,报警后我找到服务中占用磁盘最多的地方,在overlay2目录下,对下面的文件进行了删除   删除后,有状态服务先出现了问题,服务无法启动.停止. ...

  2. 本地打包Docker镜像上传至阿里云远程仓库(一站式脚本)

    打包镜像上传至远程仓库: 1. 本地项目为 mytest-project 2. 仓库为阿里云镜像仓库 registry.cn-beijing.aliyuncs.com/test/mytest-proj ...

  3. docker报错:driver failed programming external connectivity on endpoint, iptables:No chain by that name

    docker 报错: Error response from daemon: Cannot restart container hello: driver failed programming ext ...

  4. Docker容器的备份与恢复,Docker镜像的备份与恢复

    1. 备份容器 首先,为了备份Docker中的容器,我们会想看看我们想要备份的容器列表.要达成该目的,我们需要在我们运行着Docker引擎,并已创建了容器的Linux机器中运行 docker ps 命 ...

  5. docker安装kafka消息队列

    1. 启动zookeeper容器(Zookeeper用于崩溃检测,实现Topic发现,和维护Topic的生产和消费状态) docker run -d --name zookeeper -p 2181: ...

  6. 设置普通用户执行docker命令,执行docker命令无需输入密码或者切换root用户

    每次执行docker命令都要输入密码或者切换root用户,非常不方便,尤其是在shell脚本中就更麻烦了,一起来解决这个问题: 1. 创建名为docker的组,如果之前已经有该组就会提示已存在: su ...

  7. docker :open /var/lib/docker/tmp/GetImageBlob318829910: no such file or directory异常解决

    千万不要直接去重装docker,不要删除镜像,不要手动创建目录和文件,只需要这样就好了!

  8. 将jar包部署在docker上,将jar包打成镜像,使用docker部署jar包

    假设你已经准备好以下东西,即可进行服务部署 一台安装好docker的linux服务器(安装docker见安装docker) 准备好的jar包 接下来开始吧! 将jar包上传至服务器(建好文件夹存放以方 ...

  9. 使用rancher对Docker容器服务升级

    这是笔者以前使用到的一个docker管理工具--rancher 升级服务的步骤 记录一下,说不定有人需要或者以后能用上呢? 1.打包好后上传服务器,编写Dockerfile FROM jdk8apli ...

  10. Linux/docker下oracle开启监听,开启自动启动

    写在前头: 之前呢,使用docker安装了oracle,但它默认是会关闭的.使用了几天以后突然连接异常了,报的问题是oracle监听有问题了,我知道了是oracle服务自动关闭了,监听也跟着关了.所以 ...

最新文章

  1. 如何让网站打开更快第三弹--开启压缩篇
  2. hibernate主键详细介绍
  3. 在不知道根节点的情况下生成树形结构 (采用JSONObject)
  4. reverse函数实现vector变量的翻转
  5. Redis 6.0 如何实现大幅度的性能提升?
  6. Mybatis 的Log4j日志输出问题 - 以及有关日志的所有问题
  7. LeetCode 666. 路径和 IV(树的遍历)
  8. K8s 学习者绝对不能错过的最全知识图谱(内含 56个知识点链接)
  9. 解决自动更新时 系统提示“某些设置由你的系统管理员管理”的方法
  10. kylin操作系统是什么
  11. 自动生成 Makefile 的全过程详解! automake/autoconf 入门
  12. 通过Adobe Scout深入理解Flash播放器
  13. SameSite Cookie支持的浏览器版本
  14. Cousera--machine learning笔记
  15. 面试记录_智慧职安环保科技有限公司
  16. 微信公众号unionid问题
  17. 【背包DP】【2018.9.20普及组模拟】T3(WOJ 3975)保护羊村
  18. 微信小程序:小程序内用户帐号登录规范调整和优化建议
  19. Opegnl ES之四边形绘制
  20. 微信支付异常(“应答的微信支付签名验证失败“)记录

热门文章

  1. python3读取excel数据-Python3操作Excel文件(读写)的简单实例
  2. 探讨:COCO2017数据集中包含很多目标被标注为一个框bbox,是标注错误吗?
  3. lightningJS之动画
  4. 设置网络映射后,电脑重启后自动重连
  5. 网络编程学习笔记(非阻塞accept)
  6. 如何实现electron多页面间通信
  7. WPF MVVM模式下的无阻塞刷新
  8. JQuery变量数字相加的研究
  9. (转)json-lib 的maven dependency
  10. MATLAB的iptcheckinput函数详解