当前,完全硬件虚拟化技术(KVM、Xen、Hyper-V 等)能在一个物理主机上很好地运行多个互相独立的操作系统,但这也带来一些问题:性能不佳,资源浪费,系统反应迟缓等。有时候对用户来说,完全的硬件虚拟化并不是最好的选择。
一种替代方案是使用轻量级虚拟化技术 —— 所谓的 LinuX Container 容器 (LXC),它提供的是系统级虚拟化。与跑虚拟机相比,LXC 可以在一个轻量级沙箱容器里面跑多个 Linux 操作系统。当你需要设置一些易于克隆的开发环境、测试环境,或想在安全沙盒里安装应用时,LXC 就非常有用了。
Docker 是一个开源工具,可以让用户方便地布署 Linux Container 容器。Docker 很快变成了 container 技术的非官方标准,从而被 Ubuntu 和 Red Hat等众多发行版吸收进去。
本教程中我会向你们演示如何在 Ubuntu 14.04 中使用 Docker 来管理 LXC。需要注意的是,本教程的一些内容可能会与其他 Ubuntu 版本下的操作会稍微有些出入。
当前Ubuntu 系统下的 Docker 的安装包只提供64位。如果你想运行32位的 Docker,你需要使用源码编译32位 Docker 工具。
继续进行分布式开发,下面开始在Ubuntu14.04下安装Docker。
注:Ubuntu上可用的Docker程序包只支持64位系统。想在32位机器上运行它,你就要利用源代码构建32位版本的Docker,建议使用64位的。
Docker利用Linux容器(LXC)虚拟化技术提供一份部署环境。Docker目的是创建可移植,可分发给任何的Docker环境中运行。Docker由于是OpenVZ的作品,对内核有一些要求。
1.安装
安装Docker使用apt-get命令(若为非root用户,需在命令前添加sudo):
apt-get install docker.io
启动服务和守护进程
service docker.io status
service docker.io start
创建软连接,以便在外壳上使用起来更容易。
ln -sf /usr/bin/docker.io /usr/local/bin/docker
如没有提示错误则说明你已经在Ubuntu14.04上面快速安装Docker成功了。
读者也可通过下面的方法从Docker 官方源安装最新版本。首先需要安装apt-transporthttps,
并添加Docker 官方源:
sudo apt-get install apt-transport-https
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 36A1D7
869245C8950F966E92D8576A8BA88D21E9
sudo bash -c "echo deb https://get.docker.io/ubuntu docker main > /etc/apt/
sources.list.d/docker.list"
sudo apt-get update
之后,可以通过下面的命令来安装最新版本的Docker:
sudo apt-get install -y lxc-docker
在安装了Docker 官方软件源后,若需要更新Docker 软件版本,只需要执行以下命令即可升级:
sudo apt-get update -y lxc-docker
如果使用的是较低版本的Ubuntu 系统,则需要先进行内核更新并重启系统后再进行安装:
sudo apt-get update
sudo apt-get install -y linux-image-generic-lts-raring linux-headers-genericlts-
Raring
sudo reboot
重启后,重复在Ubuntu 14.04 系统的安装步骤即可。
注:在安装过程中应尽量做到将以上脚本命令整理好放在一个脚本中,以便以后进行一键式部署安装。
2.准备外壳环境
现在,我将把我的user=shq添加到docker组:
sudo usermod -a -G docker shq
或者使用:
sudo usermod -a -G docker $USER
这里,我会退出当前会话,然后再重新登录。现在,我将添加docker配置文件,以便向系统通知其位置。
sudo vi /etc/default/docker.io
DOCKER="/usr/bin/docker.io"
现在重启服务,如下所示:
sudo service docker.io restart
3.管理docker容器
3.1.下载ubuntu docker容器
安装完成后,可以使用下面的命令确定安装的版本和基本的信息。由于docker使用go语言进行编写的,所以要依赖于GO的编译工具和库文件。若要查看Docker版本信息,可输入如下命令:
sudo docker version
以下为提示信息:
镜像是Docker 运行容器的前提。
官方安装方式docker pull imagename从docker的索引中心下载,imagename是镜像名称,例如docker pull ubuntu就是下载base ubuntu并且tag是latest。pull命令用于从注册中心(registry)拉取映像或软件库。(使用pull 命令从Docker Hub仓库中下载镜像到本地)
sudo docker pull ubuntu:14.04
以下为提示信息:
Pulling repository ubuntu
c4ff7513909d: Download complete
511136ea3c5a: Download complete
1c9383292a8f: Download complete
9942dd43ff21: Download complete
d92c3c92fa73: Download complete
0ea0d582fd90: Download complete
cc58e55aa5a5: Download complete
上面的命令即从默认的注册服务器registry.hub.docker.com 中的ubuntu 仓库来下载标记为latest 的镜像。
用户也可以选择从其他注册服务器的仓库下载。此时,需要在仓库名称前指定完整的仓
库注册服务器地址。例如从DockerPool 社区的镜像源dl.dockerpool.com 下载最新的
Ubuntu 镜像。
sudo docker pull dl.dockerpool.com:5000/ubuntu
下载完成后,你也可以使用docker images 命令可以列出本地主机上已有的镜像。
sudo docker images
以下为提示信息:
使用docker inspect 命令可以获取该镜像的详细信息。
sudo docker inspect 5506de2b643b
docker inspect 命令返回的是一个JSON 格式的消息,如果我们只要其中一项内容
时,可以使用-f 参数来指定,例如,获取镜像的Architecture 信息:
sudo docker inspect -f {{".Architecture"}} 550 amd64
在指定镜像ID 的时候,通常使用该ID 的前若干个字符组成的可区分字串来替代完整的 ID。
使用docker ps -a 命令可以看到本机上存在的所有容器:
sudo docker ps -a
列出当前运行的容器, -a 会列出所有,包括已停止的, -q 只列出容器 ID,使用如下命令:
docker ps -a -q
删除所有未运行的容器,使用如下命令:
docker ps -a -q | xargs docker rm
4.启动docker容器
注:容器依赖于镜像。
下面的命令启动 Docker 里面的 Ubuntu 系统,进入交互的Shell中,最后的参数“/bin/bash”表示一旦容器启动,首先会执行简单的 bash。登录进入到Ubuntu容器的bash外壳:
sudo docker run -i -t ubuntu:14.04 /bin/bash
查看当前镜像信息,输入如下命令:
cat /etc/lsb-release
显示如下信息:
DISTRIB_ID=Ubuntu
DISTRIB_RELEASE=12.04
DISTRIB_CODENAME=precise
DISTRIB_DESCRIPTION="Ubuntu 12.04.4 LTS"
下面的内容见“分布式进阶(二)Ubuntu 14.04下安装Dockr图文教程(二)”
分布式进阶(二)Ubuntu 14.04下安装Dockr图文教程(一)
原文地址:http://blog.csdn.net/sunhuaqiang1/article/details/45745893