Docker入门
上一篇 / 下一篇 2018-07-29 15:56:22 / 个人分类:docker
文章来源
- 文章来源:【转载】
如今Docker的使用已经非常普遍,特别在一线互联网公司。使用Docker技术可以帮助企业快速水平扩展服务,从而到达弹性部署业务的能力。在云服务概念兴起之后,Docker的使用场景和范围进一步发展,如今在微服务架构越来越流行的情况下,微服务+Docker的完美组合,更加方便微服务架构运维部署落地。51Testing软件测试网*Op w7mq/LD{
本文详细解释介绍Docker入门相关内容,后期重点关注Docker在微服务体系中的使用。在了解Docker之前我们先考虑几个问题:1、Docker是什么?2、为什么要使用Docker,它有什么优势?带着这些问题我们来看看下面的内容。
P|p+OT0什么是Docker?51Testing软件测试网&t P;G0E2fqw
Docker 是世界领先的软件容器平台。开发人员利用 Docker 可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用 Docker 可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用 Docker 可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为 Linux 和 Windows Server 应用发布新功能。51Testing软件测试网*Bo"?Y-B5NHw&q0yM~
Docker 属于 Linux 容器的一种封装,提供简单易用的容器使用接口。它是目前最流行的 Linux 容器解决方案。Docker 将应用程序与该程序的依赖,打包在一个文件里面。运行这个文件,就会生成一个虚拟容器。程序在这个虚拟容器里运行,就好像在真实的物理机上运行一样。有了 Docker,就不用担心环境问题。
$_u"] T5r1I,S0总体来说,Docker 的接口相当简单,用户可以方便地创建和使用容器,把自己的应用放入容器。容器还可以进行版本管理、复制、分享、修改,就像管理普通的代码一样。51Testing软件测试网GX1U7Dug6I(V
Docker 最初是 dotCloud 公司创始人 Solomon Hykes 在法国期间发起的一个公司内部项目,它是基于 dotCloud 公司多年云服务技术的一次革新,并于 2013 年 3 月以 Apache 2.0 授权协议开源,主要项目代码在 GitHub 上进行维护。Docker 项目后来还加入了 Linux 基金会,并成立推动 开放容器联盟(OCI)。51Testing软件测试网U/KwDJ/qe9G8A%D&T
Docker 自开源后受到广泛的关注和讨论,至今其 GitHub 项目已经超过 4 万 6 千个星标和一万多个 fork。甚至由于 Docker 项目的火爆,在 2013 年底,dotCloud 公司决定改名为 Docker。Docker 最初是在 Ubuntu 12.04 上开发实现的;Red Hat 则从 RHEL 6.5 开始对 Docker 进行支持;Google 也在其 PaaS 产品中广泛应用 Docker。51Testing软件测试网i)|*F4Gjqh
为什么要使用Docker51Testing软件测试网~k JM_,H n8_
容器除了运行其中应用外,基本不消耗额外的系统资源,使得应用的性能很高,同时系统的开销尽量小。传统虚拟机方式运行 10 个不同的应用就要起 10 个虚拟机,而Docker 只需要启动 10 个隔离的应用即可。51Testing软件测试网jW6o)k@Y.r6Q
具体说来,Docker 在如下几个方面具有较大的优势。
+H p(I4Nwy7? Z#_w01、更快速的交付和部署51Testing软件测试网/dy1@ Y YeF({5P
对开发和运维(devop)人员来说,最希望的就是一次创建或配置,可以在任意地方正常运行。
5Ud:~R$U Q7S.g2{)Ek0开发者可以使用一个标准的镜像来构建一套开发容器,开发完成之后,运维人员可以直接使用这个容器来部署代码。 Docker 可以快速创建容器,快速迭代应用程序,并让整个过程全程可见,使团队中的其他成员更容易理解应用程序是如何创建和工作的。 Docker 容器很轻很快!容器的启动时间是秒级的,大量地节约开发、测试、部署的时间。51Testing软件测试网T:urQI;g l6b
2、更高效的虚拟化51Testing软件测试网x,Ez;Q6Cy7_.^
Docker 容器的运行不需要额外的 hypervisor 支持,它是内核级的虚拟化,因此可以实现更高的性能和效率。51Testing软件测试网B]{b$fe:`^
3、更轻松的迁移和扩展51Testing软件测试网+|,X2?J!J~b
Docker 容器几乎可以在任意的平台上运行,包括物理机、虚拟机、公有云、私有云、个人电脑、服务器等。 这种兼容性可以让用户把一个应用程序从一个平台直接迁移到另外一个。
v1|D,?u0bqy z8A#Zf04、更简单的管理
/a g2cxl}4^%G0使用 Docker,只需要小小的修改,就可以替代以往大量的更新工作。所有的修改都以增量的方式被分发和更新,从而实现自动化并且高效的管理。51Testing软件测试网6~/cm W fvYL2J3Wq
Docker vs VM
lI8t,qz*n HC aR@0从下图可以看出,VM是一个运行在宿主机之上的完整的操作系统,VM运行自身操作系统会占用较多的CPU、内存、硬盘资源。Docker不同于VM,只包含应用程序以及依赖库,基于libcontainer运行在宿主机上,并处于一个隔离的环境中,这使得Docker更加轻量高效,启动容器只需几秒钟之内完成。由于Docker轻量、资源占用少,使得Docker可以轻易的应用到构建标准化的应用中。但Docker目前还不够完善,比如隔离效果不如VM,共享宿主机操作系统的一些基础库等;网络配置功能相对简单,主要以桥接方式为主;查看日志也不够方便灵活。51Testing软件测试网V&q)Dx*F8g(i4yOL
Docker 在容器的基础上,进行了进一步的封装,从文件系统、网络互联到进程隔离等等,极大的简化了容器的创建和维护。使得 Docker 技术比虚拟机技术更为轻便、快捷。
(gj7tv9dK'A0J0作为一种新兴的虚拟化方式,Docker 跟传统的虚拟化方式相比具有众多的优势。Docker 容器的启动可以在秒级实现,这相比传统的虚拟机方式要快得多;Docker 对系统资源的利用率很高,一台主机上可以同时运行数千个 Docker 容器。51Testing软件测试网,Z f0{2}2NS'K.t
相关概念51Testing软件测试网-E T6h(QDI
Docker是CS架构,主要有两个概念:51Testing软件测试网 dlM)L#^` ?Mg
51Testing软件测试网 nx,o0i8t^e&O"}!{
Docker daemon: 运行在宿主机上,Docker守护进程,用户通过Docker client(Docker命令)与Docker daemon交互51Testing软件测试网0?G4ep*L7b
51Testing软件测试网 }r1xeD'a aC
Docker client: Docker 命令行工具,是用户使用Docker的主要方式,Docker client与Docker daemon通信并将结果返回给用户,Docker client也可以通过socket或者RESTful api访问远程的Docker daemon51Testing软件测试网)y;i\eP*R)n]reRY5g
51Testing软件测试网mf0^2{'D%|
51Testing软件测试网Yu&jh)LM#kr
了解了Docker的组成,再来了解一下Docker的三个主要概念:51Testing软件测试网1Sjs1UuCfv
51Testing软件测试网6j$aIV5n
Docker image:镜像是只读的,镜像中包含有需要运行的文件。镜像用来创建container,一个镜像可以运行多个container;镜像可以通过Dockerfile创建,也可以从Docker hub/registry上下载。
(aO$WT:G0U051Testing软件测试网/yW VHFzJ A*H
Docker container:容器是Docker的运行组件,启动一个镜像就是一个容器,容器是一个隔离环境,多个容器之间不会相互影响,保证容器中的程序运行在一个相对安全的环境中。51Testing软件测试网I`:v/T#d!oH3vX;H@
Docker hub/registry: 共享和管理Docker镜像,用户可以上传或者下载上面的镜像,官方地址为 https://registry.hub.docker.com/,也可以搭建自己私有的Docker registry。51Testing软件测试网j-j!tRL1S}D+R @
4h[\n^Y051Testing软件测试网X0ZM@$q-Wn(r6w
镜像就相当于打包好的版本,镜像启动之后运行在容器中,仓库就是装存储镜像的地方。
3T8fZ`(x-P0Docker安装
'XHYb|)?)i s0建议在linux环境下安装Docker,window环境搭建比较复杂且容易出错,使用Centos7+yum来安装Docker环境很方便。51Testing软件测试网(L z{*}Yv.~0K
Docker 软件包已经包括在默认的 CentOS-Extras 软件源里。因此想要安装 docker,只需要运行下面的 yum 命令:51Testing软件测试网+KZ9B+|5rGA
yum install docker 51Testing软件测试网v ?d#}&mr.B)M8@
安装完成后,使用下面的命令来启动 docker 服务,并将其设置为开机启动:51Testing软件测试网]Hh#@dM7Dff
service docker start
aV UwxX9\0chkconfig docker on
K6Jg9h+L:q[B7H0
LCTT 译注:此处采用了旧式的 sysv 语法,如采用CentOS 7中支持的新式 systemd 语法,如下:51Testing软件测试网7] X tF_9q!{6Gc
service docker start 51Testing软件测试网~h [9H8kc6v1T+t*b
chkconfig docker on