整 理:bob.zhang
时 间:2016-11-21 下午
一.特 性
一次封装到处运行,很好的说明了Docker的跨平台和强移植性。
1.Docker容器与传统虚拟机技术的特性对比
特 性 | Docker容器 | 传统虚拟机 |
---|---|---|
启动速度 | 秒级 | 分钟级 |
硬盘使用 | 一般为MB | 一般为GB |
性能 | 接近原生系统 | 相对弱于 |
系统支持量 | 单机支持上千个容器 | 一般几十个 |
2.Docker容器与传统虚拟机技术的不同之处
传统方式是在硬件层面实现虚拟化,需要有额外的虚拟机管理应用和虚拟机操作系统层。
Docker容器是在操作系统层面上实现虚拟化,直接复用本机本地的操作系统,因此更加轻量级,性能方面也更加高效。
二.核心概念
- 镜像
- 容器
- 仓库
1.镜像
Docker镜像(image)类似于虚拟机镜像,可以将它理解为一个面向Docker引擎的只读模板,包含了文件系统。
例如:一个镜像可以只包含一个完整的Centos操作系统环境,可以把它称为一个Centos镜像,镜像也可以安装了Nginx应用程序(或者用户需要的其他软件),可以把它称为一个Nginx镜像。
镜像是创建Docker容器的基础,通过版本管理和增量的文件系统,Docker提供了一套十分简单的机制(仓库)创建和更新现有镜像,用户可以从网上下载一个已经做好的应用镜像,并通过命令直接创建Docker容器来使用。
2.容器
Docker容器(Container)类似于一个箱子,可以把容器看做是一个简易的Linux系统环境(其中包括root用户权限,进程空间,用户空间和网路空间等),以及运行在其中的应用程序打包而成的一个箱子。Docker利用容器这个箱子来隔离和运行应用镜像。
容器是从镜像创建的应用运行实例,可以对他进行启动,停止,删除等常规操作。这些不同的容器之间都是相互隔离互不可见的。镜像自身是只读的,容器从镜像启动的时候,Docker会在镜像的最上层创建一个可写层,镜像本身将保持不变。
3.仓库
Docker仓库(Repostory)类似于代码的仓库(与svn、git、maven等概念类似)是Docker用来集中存放镜像文件的场所。
根据所存储的镜像是否公开分享,Docker仓库又分为:
- 1.公开仓库
- 2.私有仓库
顾名思义,公开仓库就是公共开放的镜像存储的地方,目前最大的公开仓库是Dokcer Hub (registry.hub.docker.com),存放了大量的镜像可供下载使用,国内的公开仓库有aliyun(acs-public-mirror.oss-cn-hangzhou.aliyuncs.com)。私有仓库是内部使用的私有不对外开放的仓库,用户可以内部自行搭建,内部分享镜像,方便快捷的分享专属环境的镜像文件。
三 .Docker的安装
Docker支持在所有主流操作系统上运行(Ubuntu、CentOS、Windows以及MacOS)。我这里只整理Docker在Linux(Ubuntu、CentOS)环境的安装,其他平台的安装如有需要自行Google或者度娘。
- Ubuntu
- CentOS
1.Docker在Ubuntu上的安装
3.1.1) Ubuntu14.04及以上版本的系统官方软件源中已经自带了Docker包,可以直接安装
$sudo apt-get update
$sudo apt-get install -y docker.io
$sudo ln -sf /usr/bin/docker.io /usr/local/bin/docker
$sudo sed -i '$acomplete -F _docker docker' /etc/bash_completion.d/docker.io
使用操作系统自带包安装 Docker,目前安装的版本是比较旧的版本。 要安装更新的版本,可以通过使用 Docker 源的方式。
安装最新的 Docker 版本,首先需要安装 apt-transport-https 支持,之后通过添加源来安装。
安装 apt-transport-https 支持
$ sudo apt-get install apt-transport-https
将Docker官方资料库的访问Key添加到你本地系统
$ sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80
--recv-keys 36A1D7869245C8950F966E92D8576A8BA88D21E9
$ sudo bash -c "echo deb https://get.docker.io/ubuntu docker main >
/etc/apt/sources.list.d/docker.list"
$ sudo apt-get update
$ sudo apt-get install lxc-docker
或者简单的一条命令(在系统安装了curl和apt-transport-https支持的前提下)
curl -sSL https://get.docker.io/ubuntu/ | sudo sh
3.1.2) 如果系统是Ubuntu 14.04之前的较低版本的老系统,需要先更新系统内核才能安装Docker
升级内核并重启
$ sudo apt-get update
$ sudo apt-get install linux-image-generic-lts-raring linux-headers-generic-lts-raring
$ sudo reboot
内核升级完了,然后按照上面步骤继续安装Docker即可。
安装之后启动 Docker 服务
$ sudo service docker start
2.Docker在CentOS上的安装
3.2.1) CentOS 6上安装Docker
官方文档要求Linux kernel至少3.8以上,且docker只能运行在64位的系统中。由于RHEL 6和CentOS 6的内核版本为2.6,因此必须要先升级内核(内核升级过程自行Google,度娘)。
内核升级结果确认
[root@zyb ~]# uname -r
3.10.5-3.el6.x86_64
[root@zyb ~]#
查看内核是否支持aufs:
[root@zyb ~]# grep aufs /proc/filesystems
nodev aufs
[root@zyb ~]#
首先关闭selinux:
[root@zyb ~]# setenforce 0
[root@zyb ~]# sed -i '/^SELINUX=/c\SELINUX=disabled' /etc/selinux/config
在Fedora EPEL源中已经提供了docker-io包,下载安装epel:
[root@zyb ~]# rpm -ivh http://mirrors.sohu.com/fedora-epel/6/x86_64/epel-
release-6-8.noarch.rpm
[root@zyb ~]# sed -i 's/^mirrorlist=https/mirrorlist=http/' /etc/yum.repos.d/epel.repo
yum安装docker-io:
[root@zyb ~]# yum -y install docker-io
安装之后启动 Docker 服务,并让它随系统启动自动加载,确认Docker进程:
[root@zyb ~]# chkconfig docker on
[root@zyb ~]# service docker start
Starting docker: [ OK ]
[root@zyb ~]# ps -ef|grep docker
root 70454 1 1 17:13 pts/1 00:00:00 /usr/bin/docker -d
root 70560 28112 0 17:13 pts/1 00:00:00 grep docker
[root@zyb ~]#
支持Docker在CentOS 6上安装完毕。
3.2.2) CentOS 7上安装Docker
CentOS7 系统CentOS-Extras库中已带 Docker,可以直接安装:
$ sudo yum install docker
安装之后启动 Docker 服务,并让它随系统启动自动加载。
$ sudo service docker start
$ sudo chkconfig docker on