Docker这几年的迅猛发展让容器重新流行起来,不过但很多资料里介绍Docker时都说是 "新瓶装旧酒"。除了容器外虚拟机也是我们或多或少会接触到的虚拟化技术。虚拟机和容器都用于创建隔离的虚拟环境,但是这两种虚拟化技术有显著的不同,今天的文章就来聊一下它们之间的区别。

虚拟机

虚拟机(VM)是共享一个服务器的物理资源的操作系统。它是主机硬件上的Guest,因此也被称为Guest虚拟机。

虚拟机由几层组成。支持虚拟化的层是hypervisorhypervisor是一种虚拟化服务器的软件。

虚拟机是怎么工作的

运行应用程序所需的一切都包含在虚拟机里--虚拟化的硬件,操作系统以及任何所需的二进制文件和库。因此,虚拟机具有自己独立的基础架构。

虚拟机架构图

虚拟机的优势

虚拟机可减少在服务器设备上的支出,可以利用一个物理服务器资源切分成多个独立的虚拟机来完成许多工作。

由于只有一台主机,因此可以利用虚拟机管理程序的集中功能高效地管理所有虚拟环境。这些系统完全相互独立,这意味着你可以在不同的虚拟机里安装不同的系统环境。

最重要的是,虚拟机与主机操作系统隔离,是进行实验和开发应用程序的安全场所。

虚拟机的劣势

虚拟机可能占用主机的大量系统资源,虚拟机的大小为数GB。在虚拟服务器上运行单个应用程序意味着还要运行Guest OS以及Guest OS运行所需的所有硬件的虚拟副本。这样很快就增加了很多RAMCPU资源消耗。

迁移虚拟机上运行的应用程序的过程也可能很复杂,因为它始终附加在操作系统上。因此,必须同时迁移应用程序和操作系统。同样,在创建虚拟机时,系统管理程序会分配专用于VM的硬件资源。不过与运行单独的实体服务器相比,这仍然是经济的。

容器

容器是一个不依赖于操作系统,运行应用程序的环境。它通过Linux的NamespacesCgroups技术对应用程序进程进行隔离和限制的,Namespace的作用是隔离,它让应用进程只能看到该Namespace内的世界;而Cgroups 的作用是限制分配给进程的宿主机资源。但对于宿主机来说,这些被“隔离”了的进程跟其他进程并没有太大区别。

容器只是运行在宿主机上的一种特殊的进程,多个容器之间使用的还是同一个宿主机的操作系统内核。

关于NamespacesCgroups后面再详细介绍,这里你只知道他们是启动隔离和限制应用进程的就行了。

容器是怎么工作的

Namespace的作用是隔离,它让应用进程只能看到该Namespace内的世界;而Cgroups的作用是限制,它给这个世界围上了一圈看不见的墙。通过Mount Namespace可以修改容器进程对自己的文件系统 "挂载点"的认知。在容器进程启动之前重新挂载它的整个根目录"/"(通过pivot_root系统调用改变进程的文件系统,如果系统不支持,则使用chroot),而由于Mount Namespace的存在,这个挂载对宿主机不可见的。这个挂载在容器根目录上、用来为容器进程提供隔离后执行环境的文件系统,就是所谓的“容器镜像”。它还有一个更为专业的名字,叫做:rootfs(根文件系统)。rootfs只是一个操作系统所包含的文件、配置和目录,并不包括操作系统内核。

所以说,rootfs 只包括了操作系统的 "躯壳",并没有包括操作系统的内核。同一台机器上的所有容器,都会共享宿主机操作系统的内核。

这就意味着,如果容器里的应用程序需要配置内核参数、跟内核进行直接的交互,这些都是操作的宿主机操作系统的内核,它对于该机器上的所有容器来说是一个“全局变量”,牵一发而动全身。这也是容器相比于虚拟机的主要缺陷之一:毕竟虚拟机有模拟出来的硬件机器充当沙盒,而且每个虚拟机里还运行着一个完整Guest OS让应用随便折腾。不过由于rootfs里打包的不只是应用,而是整个操作系统的文件和目录,也就意味着,应用以及它运行所需要的所有依赖,都被封装在了一起。这就赋予了容器所谓的一致性:无论在本地、云端,还是在一台任何地方的机器上,用户只需要解压打包好的容器镜像,那么这个应用运行所需要的完整的执行环境就能被重现出来。

容器的优势

容器占用的大小比虚拟机小很多,甚至可以小到10MB,可以轻松限制容器的内存和CPU使用率。与部署应用需要部署整个操作系统的虚拟机相比,容器非常轻巧且启动迅速。这样让我们可以快速扩展容器并添加相同的容器。

同样,容器对于持续集成和持续部署(CI / CD)实施也是极好的选择。他们通过在开发人员之间分发和合并镜像来促进协作开发。

容器的劣势

容器仍无法提供与虚拟机相同的安全性和稳定性。由于它们共享主机的内核,因此不能像虚拟机一样完全隔离。

容器是进程级的隔离,一个容器可以通过影响宿主机内核的稳定性来影响其他容器。

一旦容器执行了任务,它就会关闭并删除其中的所有数据。如果希望数据保留下来,则必须使用"数据卷"进行保存,这需要在主机上进行手动配置。

容器还是虚拟机

上面我们列出了容器和虚拟机各自的优势和劣势,我们在因为优势选择了其一后默认就要其忍受劣势所带来的副作用,凡事都有两面性没有东西可以只有优点没缺点的。就容器和虚拟机来说,因为其完整的隔离和安全性虚拟机通常用于要求苛刻的应用程序,网络基础结构以及能消耗VM大部分资源的应用程序。而容器通常用于Web应用,微服务。

Kubernetes部署运行Go项目

运行在笔记本上的Kubernetes集群

Go并发编程里的数据竞争以及解决之道

❤️爱心三连

1.看到这里了就点个在看支持下吧,你的「在看」是我创作的动力。

2.关注公众号网管叨bi叨,「每周为您分享原创技术文章」!

3.特殊阶段,带好口罩,做好个人防护。

“在看转发”是最大的支持

容器和虚拟机到底有啥区别?相关推荐

  1. 虚拟文件系统模拟_容器和虚拟机到底有啥区别?

    Docker这几年的迅猛发展让容器重新流行起来,不过但很多资料里介绍Docker时都说是 "新瓶装旧酒".除了容器外虚拟机也是我们或多或少会接触到的虚拟化技术.虚拟机和容器都用于创 ...

  2. 影子系统、沙盒、虚拟机的区别,沙盒化容器:是容器还是虚拟机,容器、虚拟机、虚拟环境的区别

    1 容器和虚拟机的区别 虚拟机是操作系统级别的资源隔离,而容器本质上是进程级的资源隔离. 2 虚拟机和虚拟环境的区别 虚拟环境是为了隔绝用户的多个运行环境,避免冲突. 虚拟机是为了隔绝多个用户之间的操 ...

  3. 容器与Pod到底有什么区别和联系?

    点击上方"朱小厮的博客",选择"设为星标" 后台回复"书",获取 后台回复"k8s",可领取k8s资料 容器本可以成为轻 ...

  4. 虚拟服务器容器,docker容器和虚拟机的区别

    结构方面区别 虚拟机实现资源隔离的方式,是利用Hypervisor虚拟化 而 简单来说,Docker就是利用namespace实现的系统环境的隔离,利用cgroup实现资源限制,利用镜像实现根环境的的 ...

  5. Docker,容器,虚拟机和红烧肉

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. Docker是什么?容器又是什么? Docker 直译:码头工人.是在码头上搬运货物的工人 容器 英 ...

  6. 容器和虚拟机水火不容?不存在的!

    最近一两年来,以容器为代表的云原生技术一直是IT行业最为热门的话题.随着云原生技术的崛起,有企业甚至跳过了IaaS层直接在物理机上部署容器.容器的风头几乎盖过云计算,虚拟化技术甚至由此被认为是传统方法 ...

  7. Spring 和 Spring Boot 之间到底有啥区别?

    概述 对于Spring和SpringBoot到底有什么区别,我听到了很多答案,刚开始迈入学习SpringBoot的我当时也是一头雾水,随着经验的积累.我慢慢理解了这两个框架到底有什么区别,相信对于用了 ...

  8. spring boot security ajax_Spring 和 SpringBoot 之间到底有啥区别?

    来源:uee.me/cNDC8 概述 对于 Spring和 SpringBoot到底有什么区别,我听到了很多答案,刚开始迈入学习 SpringBoot的我当时也是一头雾水,随着经验的积累.我慢慢理解了 ...

  9. spring揭秘_被问到了! Spring 和 Spring Boot 之间到底有啥区别?

    相信很多小伙伴和我一样,常用Spring 和Spring Boot 但是就是没有研究二者之间到底有什么区别? 今天就来大揭秘 ↓ 概述 对于 Spring和 SpringBoot到底有什么区别,我听到 ...

最新文章

  1. java.lang.VerifyError
  2. 为什么将 0.1f 改为 0 会使性能降低 10 倍?
  3. linux系统预定义变量有哪些,Shell预定义变量用法详解
  4. SDN/NFV运营商商业化部署
  5. asp获取手机mac_asp.net 获取客户端IP与mac
  6. 《SAS编程与数据挖掘商业案例》学习笔记之二
  7. cef 前进后台 实现_CefSpider: 一个基于Webkit,Cef框架构建爬虫,项目代号:“车风”,具备浏览器所有特性,欢迎你给我一个Star,你的Star是该项目前进的动力!...
  8. 关于Windows 1803版本内核隔离打开后无法关闭的解决方案
  9. ITU-T Technical Paper: IP服务性能模型
  10. 百度如流首发AI智能办公标准 ,BATH持续发力企业办公
  11. 安溪八中高考2021成绩查询,2020福建省地区高考成绩排名查询
  12. 调用百度语音合成API,Qt实现语音合成,Qt语音合成
  13. JS实现放大镜特效原理解析
  14. 罗振宇《时间的朋友》2017跨年演讲摘要
  15. 小米笔记本 wifi linux,被小米笔记本的WiFi坑了一道
  16. 《万人如海一身藏》书摘
  17. HTTPS,SSL,TLS
  18. SpringBoot之事务处理:隔离级别与传播行为
  19. python数字切片_Python学习笔记-数字,列表,元祖,切片,循环
  20. TP简约自适应导航网站源码

热门文章

  1. Python爬虫环境常用库安装
  2. SQL Server 导入bak备份出错
  3. MySQL常用函数系列之九:日期和时间函数 函数(4)
  4. (六)企业部分之jdk
  5. 敏捷开发方法XP的12个最佳实践
  6. oracle developer 连接 mysql
  7. 【补充一则】身份证校验的c#代码
  8. asp.net 递归删除文件夹及其子文件夹和所有文件[转]
  9. HTTP协议头部与Keep-Alive模式详解-Content-Length Transfer-Encoding
  10. 如何提高JVM的性能?