Docker 和一个正常的虚拟机有何区别?

问: 

我多次重读Docker.io文档,希望搞明白Docker.io和一个完全的虚拟机的区别。Docker是如何做到提供一个完整的文件系统,独立的网络环境等等这些功能,同时还没有如此庞大? 

为什么部署软件在一个docker镜像(image)比部署在一致的生产环境上要容易? 




答: 

当前,Docker内部使用的是Linux容器技术(LXC),这是运行在与它的宿主机器同样的操作系统上。这准许它可以和宿主机器共享许多系统资源。它也会使用AuFS作为文件系统,也为你管理网络。 

AuFS是一个层状的文件系统,因此你可以有一个只读部分和一个只写部分,然后将二者组合起来。你可以使系统的共同的部分用作只读,那块是被所有容器共享,并且给每个容器自己的可写区域 

 

好吧,让我们假设你有一个容器镜像(image)容量是1GB,如果你想用一个完整的虚拟机来装载,你得需要容量的大小是1GB乘上你需要虚拟机的数量。但使用Linux容器虚拟化技术(LXC)和AuFS,你可以共享1GB容量,如果你需要1000个容器,假设他们都运行在同样的系统影像上,你仍然可以用稍微比1GB多一点的空间来给容器系统, 

一个完整的虚拟化系统得到了分给它的自有全部资源,只有最小的共享。你获得了更多的隔离,但是这是很庞大的(需要更多的资源) 

使用Linux容器虚拟化技术(LXC),隔离性方面有所缺失,但是他们更加轻量,而且需要更少资源。所以你可以轻松运行1000个容器在一个宿主机器上,甚至眼都不眨。试着用Xen来实现那个,我想除非你有一个超级强大的主机,不然我看是不可能的了

 

一个完整的虚拟系统通常得用几分钟去启动,linux容器虚拟技术(LXC)只要数秒,甚至有时时间更短。 

对于每种虚拟系统都有反对者和支持者。如果你希望一个完全隔离的和资源有保障的环境,那么完全的虚拟机是你的选择。如果你只希望进程之间相互隔离,并且希望大量运行他们在一个合理大小的宿主机器上。那么linux容器虚拟技术(LXC)是你的选择。

更多有关信息,可以参考这些博客,这非常详细介绍了LXC的工作 http://blog.dotcloud.com/under-the-hood-linux-kernels-on-dotcloud-part

"为嘛在docker镜像上部署软件比在一致生产环境上容易?"我觉得问这个问题是非常愚蠢的 

 

部署一个一致的生产环境说起来容易做起来难。即使你使用了chef 和puppet之类的工具,像操作系统升级,还有一些其它的事情而造成的主机及环境之间的改变,往往是常有的事。 

docker所做的事情就是赋予你一种能力,使你可以将OS快照存入一个通用的镜像,并使得在往其它的docker主机上部署时变得容易。对于本地,开发、质量管理、产品等等,都是用的同一个镜像。当然你也可以用其它的工具来做到这一点,但是可能没有这么容易或者这么快。 

 

这对于单元测试是非常棒的。让我们来看看你有1000个测试,而且都需要连接数据库。为了不破坏任何事情,你需要一个接着一个的运行,以便这些测试不会相互影响(每个测试都在事务中,然后回滚回去)。使用Docker,那么你可以创建一个数据库的镜像(image),既然你知道这些测试会运行在相同的的数据库快照下,那么就可以并行地运行所有测试。既然这些测试都是并行运行在linux容器中,那么他们可以同时运行在同样的环境中。这样你的测试会完成的非常快。试着用完整的虚拟机来做这件事。 

编辑:来着评论… 

有趣!我觉得我仍然对于“系统快照”的概念有些模糊,如何没有使用这些系统  像(image)会怎么样啊? 


好的,试着看我能不能解释。你开始有个基础  镜像(image),然后进行改变数据,并且使用docker提交这些改变,这个会建立一个镜像(image),这个  镜像(image)只包含数据改变的部分。当你想运行你的这个  镜像(image)你仍然需要这基础  镜像(image),然后使用层式的文件系统,将你的映像置于基础映像之上,这个例子中用AUFS,AUFS将不同层融合起来,然后你就会得到你想要的,你只要简单运行就可以了。你可以增加许多的  镜像(image),这些  镜像(image)只会记录改变的地方。



转自:http://www.oschina.net/translate/how-is-docker-io-different-from-a-normal-virtual-machine
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker虚拟机是两种不同的虚拟化技术,它们在实现原理和应用场景上有一些区别。 1. 架构差异: - 虚拟机虚拟机通过在物理服务器上运行一个完整的操作系统实例来实现虚拟化。每个虚拟机都有自己的内核、操作系统和应用程序,它们是相互隔离的。 - DockerDocker 使用容器来实现虚拟化。容器是在操作系统级别隔离的进程,它们共享宿主机操作系统的内核,但具有独立的文件系统和资源隔离。 2. 资源消耗: - 虚拟机:由于每个虚拟机都需要运行一个完整的操作系统,因此会占用较多的计算资源和内存。 - Docker:由于容器共享宿主机操作系统的内核,因此容器之间的资源消耗更低,启动和停止容器也更加快速。 3. 部署和启动速度: - 虚拟机:由于每个虚拟机都需要运行完整的操作系统,因此部署和启动虚拟机需要较长的时间。 - Docker:由于容器共享宿主机操作系统的内核,容器的部署和启动速度非常快。 4. 隔离性: - 虚拟机虚拟机之间具有较高的隔离性,每个虚拟机都是独立的操作系统实例。 - Docker:容器之间也具有一定的隔离性,但它们共享宿主机的内核,因此容器之间的隔离性相对较弱。 5. 应用场景: - 虚拟机虚拟机适用于需要隔离、安全性要求较高的场景,例如在不同操作系统之间进行开发和测试,或者部署复杂的应用程序。 - DockerDocker 适用于快速部署、扩展和管理应用程序的场景,尤其在微服务架构和持续集成/持续部署流程中广泛应用。 总的来说,虚拟机提供了更高的隔离性和安全性,但资源消耗较高,启动速度较慢;而 Docker 提供了更快速的部署和启动速度,资源消耗较低,适合快速构建和部署应用程序。根据具体需求和场景的不同,选择合适的虚拟化技术可以提高效率和资源利用率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值