Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别

简介: Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别

Docker的思想来自于集装箱,在一艘大船上,可以把货物规整的摆放起来,并且各种各样的货物被集装箱标准化了,集装箱和集装箱之间不会互相影响,那么我就不需要专门的运送水果云手那个化学品的船了,只要这些货物在集装箱里封装的好好的,那么我就可以用一首大船把他们运走,docker就是类似的理念 。

      通过Docker能够把net,PHP,开发的应用作为容器(集装箱)运行,.netPHP开发的两个应用是各自的独立环境,基于容器(集装箱)可以运行多种应用,redid,mysql,tomcat,centos等等,总之Docker就是集装箱的原理

1.3 Docker的用途

1.3.1 提供统一的运行环境

在生产环境中,很多时候的开发,测试及上线环境都是不一样的,从而导致项目(war或者jar)在不同的阶段出现很多其他阶段所不存在的奇怪的问题。

      Docker容器除了可以提供相同的应用外,还提供了该应用的统一运行环境,确保在任何宿主机HOST上都可以跑出相同的结果,即Docker = jar/war+环境。

名称解释:

宿主机:容器想要运行就需要有个机器,这个机器就是宿主机。

1.3.2 便捷的应用迁移

由于Docker确保了统一运行环境,使得应用的迁移更加便捷,无论是物理机,虚拟机,公有云,私有云,Docker镜像的运行结果都是相同的,用户可以很方便的将一个平台上运行的应用迁移到另一个平台上,而无需担心运行环境的变化导致应用无法正常运行。

1.3.3 超快的启动时间及更简单的管理

传统的虚拟机技术启动应用一般需要数分钟,首先要启动虚拟机,然后在加载虚拟机操作系统,最后还需要再手工启动应用。而Docker容器应用,由于直接进行宿主机中,无需启动操作系统,因此可以做到秒级,甚至毫秒级的启动。

      使用Docker只需要小小的修改,就可以替代以往大量的更新工作,所有的修改都已增量的方式被分发和更新,从而实现自动化并且高效的管理。

1.3.4更轻松地维护和扩展

Docker公司及各个开源项目团队一起维护了一大批高质量的官方镜像,即可以直接在生产环境使用,又可以作为基础进一步定制,大大的降低了应用服务的镜像制作成本。

      Docker使用的分成存储及镜像的技术,使得应用重复部分的复用更为容易,也使得应用的维护更新更加简单,基于基础镜像进一步扩展镜像也变得非常简单。

1.4 容器与虚拟机的区别

Docker容器的本质就是通过容器虚拟技术虚拟出的一台主机,就像虚拟机一样,可以将应用及其运行环境部署在这台虚拟出的主机上运行,但是容器与虚拟机又有着本质的不同。

1.4.2传统虚拟技术

传统的虚拟技术是在物理机的操作系统之上安装一个虚拟机管理程序,例如VMware,VirtualBox等,在其管理下可以创建很多个虚拟机,每个虚拟机需要安装自己独立的操作系统,而应用就是安装在虚拟机操作系统之上的应用程序,应用程序通过调用各种命令或库函数来使用其需要的各种系统资源。

      对于玩全相同的两个应用,其若需要运行在两个虚拟机中,则就需要两套完全相同或的虚拟机操作系统与bins/libs,存在大量的资源占用冗余,形成资源浪费。

1.4.3容器虚拟化技术

Docker容器运行在Docker引擎之上,所有Docker共享同一个Docker引擎,但它们有时相互隔离,互补干扰的,由于Docker容器不需要进行虚拟硬件及操作系统,而是共享宿主机的硬件与操作系统,所以Docker容器对系统资源的占用很少,其仅包含运行时必须的一些资源。所有Docker容器对于系统资源的使用都是由Docker引擎统一进行管理,所以对系统资源的利用率很高,无论是应用执行速度,内存损耗或者文件存储速度都要比传统虚拟机技术更高效。

1.4.4普通系统中的程序运行原理

程序:程序是一个对计算机硬件资源调度使用的指令序列。

1.4.5容器系统中的程序运行原理

Docker容器运行在Docker引擎之上,所有Docker容器共享同一个Docker引擎,但他们的运行又是相互隔离,又互不干扰,由于docker容器不需要进行虚拟硬件及操作系统,而是共享的宿主主机的硬件与操作系统,所以Docker容器对系统资源占用较少,其仅包含运行时必须的一些资源,所有Docker容器对于系统资源的使用都是由docker引擎统一进行管理,所以对系统的资源的利用率很高,无论是应用执行速度,内存损耗或者文件存储速度都要比传统虚拟机技术更高效。

1.5 Window系统的虚拟化

1.5.1 Hypervisor

Hypervisor ——一种运行在基础物理服务器和操作系统之间的中间件层,可允许多个操作系统和应用共享硬件,也可以叫做VMM,即虚拟机监视器。

      Hypervisor是一种在虚拟环境中的"元"操作系统,他们可以访问服务器上包括磁盘和内存在内的所有物理设备,hypervisor不但协调着这些硬件资源的访问,也同时在各个虚拟机之间施加防护,当服务器启动hypervisor时,它会加载所有虚拟机客户端的操作系统同时会分配给没一台虚拟机适量的内存CPU网络磁盘

1.5.2 Hyper-V

hyper-V是微软的一款虚拟化产品,是微软第一个采用类似Vmware ESXCitrux Xen基于hypervisor的技术,这也意味着微软会更加直接的与市场先行者VMware展开竞争,但竞争的方式会有所不同。

      Hyper-V是微软提供的商业化的HypervisorKVMXEN都是linux系统之上的开源的Hypervisor

1.5.3 现在的Windows系统

现在Windows系统并不是一个“纯洁”的windows了,而是运行在Hyoer-V上的虚拟机。而原来的应用层现在也是一个运行在Hyper-V上的虚拟机,系统上运行的一个个的应用其实就是运行在应用层虚拟机之中。操作系统虚拟机能够管理应用层虚拟机。

1.5.4 Windows系统的启动过程

1.5.5 Vmware与windows系统

VMware采用的是VMM虚拟化技术,该技术要求直接访问CPU硬件的虚拟化功能,但VMware作为windows系统中的应用是运行在应用层虚拟中的,导致VMware无法直接访问CPU硬件虚拟化功能,所以安装Vmware Workstation时会出现VMware WorkstationHyper-V不兼容的问题。

      从VMware Workstation15.5.5版本开始,VMware重构了WMM技术,使其不需要直接访问CPU硬件,而是通过windows10系统的WHPAPI来运行。

      结论:我们在安装Vmware Workstation时,要安装15.5.5版本或更高版本,而Windows系统也要使用Windows10或者更高版本。

1.6 Docker系统架构

Docker中具有几个非常重要的概念,通过理解概念来了解Docker的系统架构。

Docker DaemonDockerd,docker守护进程, 其监听者Docker API请求并管理Docker对象,例如镜像,容器,网络和卷,守护进程还可以与其他守护进程通信以管理Docker服务。

1.6.2 镜像Image


相关文章
|
1月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
232 77
|
2天前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
41 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
13天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
1天前
|
运维 Java 虚拟化
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
38 12
|
19天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
95 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
2天前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
31 10
|
25天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
50 3
实战~如何组织一个多容器项目docker-compose
|
16天前
|
存储 数据挖掘 数据库
虚拟化数据恢复—VMFS简介&误删除虚拟机的数据恢复案例
物理区:物理上连续的磁盘空间,即通常意义上的分区。 本地区:VMFS管理的物理区分为保留区和本地区,前面一部分是保留区,后面部分是本地区。本地区又分为元文件区和数据区。 元文件:与NTFS的元文件类似,属于FS的管理用数据。VMFS有6个元文件:.VH.SF/.FBB.SF/.FDC.SF/.SBC.SF/.PBC.SF/.PB2.SF。 元文件区:6个元文件占用的所有空间,在本地区的前面部分。 数据区:用于存放文件数据。 datastore:在ESX服务器上看到的VMFS存储空间。 LV:logical volume,所指的范围其实和本地区一样,即虚拟化卷。 LVM逻辑卷组:用来管理跨dis
|
1月前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
117 3