Docker (1) 基本概念和框架

Docker简介

什么是容器?

  一种虚拟化的方案,操作系统级别的虚拟化。容器是一个轻量的、独立的、可执行的包,包含了执行它所需要的所有东西:代码、运行环境、系统工具、系统库、设置。很长一段时间中,容器是专门用于Linux内核的,但微软和Docker的密切合作将容器带到了微软平台上,现在可以再Linux、windows、Azure、Mac等等操作系统上使用。

虚拟机和容器的区别

  磁盘占用空间更少(虚拟机除了应用的运行环境外,还需要安装操作系统。几个G,而容器只需要包含应用程序和它依赖的库)

  资源占用减少(虚拟机需要模拟硬件的行为,对内存和CPU的损耗特别大,同样配置的服务器使用容器要比使用虚拟机服务更多的客户)

  没有docker前,容器技术很复杂,不容易安装,也不容易管理实现自动化,而docker就是为了改变些。

什么是Docker?

   是一个由GO语言编写的程序运行的“容器”,目前容器服务的基石是操作系统级别的隔离,在同一台物理服务器上虚拟出多个主机。Docker则实现了一种应用程序级别的隔离,它改变我们基本的开发、操作但愿,由直接操作虚拟主机,转换到操作程序运行的“容器”上来。

  Docker的英文本意是码头工人,也就是搬运工,这种搬运工搬运的十集装箱(Container),集装箱里面装的可不是商品货物,而是任意类型的App,Docker把App装在Container内,通过Linux Container技术的包装将App变成一种标准化的、可移植的、自管理的组件,这种组件可以再你的Laptop上开发、调试、运行,最终非常方便和一致地运行在生产环境下。Docker的核心底层技术是(Linux Container)LXC,Docker在其上面加了薄薄的一层,添加了许多有用的功能。

  Docker不仅是历史上最流行的开源项目之一,而且也从跟上上改变了人们构建应用程序的思维方式,它可以把程序集依赖的二进制文件、第三方库等封装在一起,运行在任何安装Docker Deamon的服务器上,它有望成为未来软件自动化部署的标准。

  

Docker的目标

  “Build, Ship And Run Any APP, Anywhere” 编译,装载任何APP,在任何地方都可以运行。

  大概就是一个容器,实现了对应用的封装,部署,运行等声明周期管理,只要在(go语言依赖的环境)glibc的环境下,导出都可以运行。

Docker与虚拟机的区别

可见每一个虚拟机包括应用、必要的二进制文件和库、完整的客户端操作系统,大小总计十几个GB。容器包括应用和应用的所有依赖,每个容器都使用容器自身选择的发型版本,但是与其他容器共享宿主操作系统的内核。在宿主操作系统的用户空间内,他们以隔离的进程方式运行。另外,他们并不像客户端操作系统正常运行那样运行所有的进程。而且容器也补绑定任何特别的硬件基础设施,Docker容器在任何计算机任何硬件基础设施任何云上都可以运行。

更重要的是,虚拟机需要耗时几分钟才能启动,而且对资源敏感,然后容器只需要几秒启动,在资源较少负载过大时也能应付的了。所以,可以再本地计算机运行很少的几个虚拟机用于开发目的,但是可以运行很多很多的容器。

Docker的使用场景

  1.使用Docker容器开发、测试、部署服务

  2.创建隔离的运行环境

  3.搭建测试环境

  4.构建多用户的平台即服务(PaaS)基础设施

  5.提供软件即服务(Saas)应用程序

  6.高性能、超大规模的宿主机部署

Docker的基本组成

Docker是C/S架构的程序, 由下面三部分组成:

  Docker Client 客户端:Docker 命令行工具,是用户使用Docker的主要方式,Docker client与Docker daemon通信并将结果返回给用户,Docker client也可以通过socket或者RESTful api访问远程的Docker daemon(守护进程 服务端)

  Docker Daemon 守护进程:Docker 守护进程,也就是Server端,Server端可以部署在本地,也可以部署在远程,因为Server端与客户端是通过Rest Ful API进行通信的。

  Docker Image 镜像:镜像是一个层叠的只读文件,镜像中包含有需要运行的文件。镜像用来创建container,一个镜像可以运行多个container,镜像可以通过Dockerfile创建,也可以从Docker hub/registry上下载。

  Docker Container 容器:容器是Dcoker的运行组件,启动一个镜像就是一个容器,容器是一个隔离环境,多个容器之间不会相互影响,保证容器中的程序运行在一个相对安全的环境中。容器基于镜像启动和运行。

  Docker Registry 仓库:共享和管理Docker镜像,用户可以上传或者下载上面的镜像,官方地址为:https://registry.hub.docker.com/ 也可以搭建自己私有的Docker registry

Docker的优点

  Docker提供了一种可移植的配置标准化机制,允许你一致性地在不同的机器上运行同一个Container,而LXC(Linux Container)本身可能因为不同机器的不同配置而无法方便的移植运行。

    Docker以App为中心,为应用的部署做了很多优化,而LXC的帮助脚本主要是聚焦于如何使机器启动地更快和小号更少的内存。

  Docker为App提供了一种自动化构建机制(Dockerfile),包括打包,基础设施管理和安装等。

  Docker提供了一种类似git的Container版本化的机制,允许你对你创建过的容器进行版本管理,依靠这种机制,你还可以下载别人的Container,甚至像git那样合并。

  Docker Container 是可重用的,依赖于版本化机制,你很容易重用别人的Container,作为基础版本进行扩展

  Docker Container 是共享的,有点类似github一样,Docker有自己的Index,你可以创建自己的DOcker用户并上传和下载Docker Image

  Docker提供了很多的工具链,形成了一个生态系统,这些工具的目标是自动化、个性化和集成化,包括对PASS平台的支持等。

  速度快:运行时的性能可以获取极大提升,管理操作(启动、停止、开始、重启等)都是以秒为单位的,将应用和系统容器化,不添加额外的操作系统。

  敏捷:比VM小,比VM快,Docker容器的尺寸减小相比整个虚拟机大大简化了分布到于和仍与分发灵活。

  轻量:你会拥有足够的操作系统,仅需添加或减小镜像即可。在一台服务器上可以部署100~1000个Containers容器。

  便宜:开源的、免费的、低成本的。由现代Linux内核支持驱动,轻量的Container必定可以再一个物理机上开启更多容器,注定比VM要便宜。

猜你喜欢

转载自www.cnblogs.com/baidawei/p/9198308.html