什么是docker?
docker的优点:
1、更高效的利用系统资源---docker类似于传统虚拟化、但又比其更节省资源。
2、更快速的启动时间---秒级、毫秒级启动
3、一致的运行环境---从而不会再出现“这段代码在我机器上没问题”这类问题
4、持续的交付和部署---
5、更轻松的迁移---共有云、私有云上任意迁移
6、更轻松的维护和扩展---可在原有镜像的基础上进一步定制
docker三大组成:
一、Docker镜像
每个dorker镜像都有自身的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外、还包括了一些配置参数(环境变量、用户等)。镜像不包含任何动态数据、其内容在构建之后不会被改变。
1、分层存储
镜像构建时、会一层层构建、前一层是后一层的基础。没一层构建完就不会再发生改变,后一层上的任何改变只发生在自己这一层。在构建镜像时,需要额外小心,每一层尽量只包含该层需要添加的短信,任何额外的短信应该在该层构建结束前清理掉。
二、docker容器
镜像是静态的定义,容器是镜像运行的实体。容器可以被创建、启动、停止、暂停等。
容器的实质是进程,但与直接在宿主执行进程不同,容器进程运行于自己的独立的命名空间,此容器可以拥有自己的ROOT文件系统、自己的网络配置、自己的进程空间、甚至自己的用户ID空间。
每一个容器运行时,是以镜像为基础层,在其上创建一个当前容器的存储层,我们可以称这个为容器运行时读写而准备的存储层为容器存储层。
容器不应该向其存储层内写入任何数据,容器存储要保存无状态化。所有的文件写入操作。都应该使用数卷、或绑定宿主目录,在这些位置的读写会跳过容器存储层,直接对宿主发生读写,其性能和稳定性更高。
三、Docker仓库
镜像构建完成后,可以很容易的当前宿主上运行,但是如果需要在其他服务器上使用这个镜像,我们就需要一个集中存储,分发镜像的服务,Docker Registry就是这样的服务。
一个 Docker Registry 中可以包含多个仓库(Repository);每个仓库可以包含多个标签(Tag);每个标签对应一个镜像。
通常,一个仓库会包含同一个软件不同版本的镜像,而标签就常用于对应该软件的各个版本。我们可以通过 <仓库名>:<标签> 的格式来指定具体是这个软件哪个版本的镜像。如果不给出标签,将以 latest 作为默认标签。
以Ubuntu 镜像为例,ubuntu 是仓库的名字,其内包含有不同的版本标签,如,14.04, 16.04。我们可以通过 ubuntu:14.04,或者 ubuntu:16.04 来具体指定所需哪个版本的镜像。如果忽略了标签,比如 ubuntu,那将视为 ubuntu:latest。
仓库名经常以 两段式路径 形式出现,比如 jwilder/nginx-proxy,前者往往意味着 Docker Registry 多用户环境下的用户名,后者则往往是对应的软件名。但这并非绝对,取决于所使用的具体 Docker Registry 的软件或服务。
安装条件:
Docker 最低支持 CentOS 7。
Docker 需要安装在 64 位的平台,并且内核版本不低于 3.10
安装Docker
#yum update 更新内核
#yum install docker yum 安装docker
#systemctl enable docker 启动docker引擎
#systemctl start docker 启动docker引擎
建立docker用户组,出于考虑不直接用root跑。
#groupadd docker 建立Docker组
#usermod -aG docker $USER 将某个用户添加到组里。
镜像加速器:
#systemctl enable docker 启用服务后
#vi /etc/systemd/system/multi-user.target.wants/docker.service
找到 ExecStart= 这一行
添加如下(添加蓝色部分):ExecStart=/usr/bin/dockerd --registry-mirror=https://jxus37ad.mirror.aliyuncs.com
重新加载配置 #systemctl daemon-reload
重启服务 #systemctl restart docker
验证方法: #ps -ef | grep dockerd 可以看到添加的内容--registry-mirror,如下图。