美文网首页
Docker (一) Docker的特性,核心概念及安装

Docker (一) Docker的特性,核心概念及安装

作者: 十点半的晚安 | 来源:发表于2016-11-21 17:36 被阅读0次

整 理:bob.zhang
时 间:2016-11-21 下午


一.特 性

一次封装到处运行,很好的说明了Docker的跨平台和强移植性。

1.Docker容器与传统虚拟机技术的特性对比

特 性 Docker容器 传统虚拟机
启动速度 秒级 分钟级
硬盘使用 一般为MB 一般为GB
性能 接近原生系统 相对弱于
系统支持量 单机支持上千个容器 一般几十个

2.Docker容器与传统虚拟机技术的不同之处

传统方式是在硬件层面实现虚拟化,需要有额外的虚拟机管理应用和虚拟机操作系统层。


传统虚拟化与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


相关文章

网友评论

      本文标题:Docker (一) Docker的特性,核心概念及安装

      本文链接:https://www.haomeiwen.com/subject/ytbjpttx.html