天天看点

CentOS 安装 Docker CE

准备工作

系统要求

Docker CE 支持 64 位版本 CentOS 7,并且要求内核版本不低于 3.10。 CentOS 7 满足最低内核的要求,但由于内核版本比较低,部分功能(如 overlay2 存储层驱动)无法使用,并且部分功能可能不太稳定。

卸载旧版本

旧版本的 Docker 称为 docker 或者 docker-engine,使用以下命令卸载旧版本:

<code>$ </code><code>sudo</code> <code>yum remove docker \</code>

<code>                  </code><code>docker-common \</code>

<code>                  </code><code>docker-selinux \</code>

<code>                  </code><code>docker-engine</code>

使用 yum 源 安装

执行以下命令安装依赖包:

<code>$ </code><code>sudo</code> <code>yum </code><code>install</code> <code>-y yum-utils device-mapper-persistent-data lvm2</code>

鉴于国内网络问题,强烈建议使用国内源,下面先介绍国内源的使用。

国内源

执行下面的命令添加 yum 软件源

<code>$ </code><code>sudo</code> <code>yum-config-manager \</code>

<code>    </code><code>--add-repo \</code>

<code>    </code><code>https:</code><code>//mirrors</code><code>.aliyun.com</code><code>/docker-ce/linux/centos/docker-ce</code><code>.repo</code>

以上命令会添加稳定版本的 Docker CE yum 源。从 Docker 17.06 开始,edge test 版本的 yum 源也会包含稳定版本的 Docker CE。

官方源

<code>    </code><code>https:</code><code>//download</code><code>.docker.com</code><code>/linux/centos/docker-ce</code><code>.repo</code>

如果需要最新稳定版本的 Docker CE 请使用以下命令:

<code>$ </code><code>sudo</code> <code>yum-config-manager --disable docker-ce-edge</code>

<code>$ </code><code>sudo</code> <code>yum-config-manager --disable docker-ce-</code><code>test</code>

安装 Docker CE

更新 yum 软件源缓存,并安装 docker-ce。

<code>$ </code><code>sudo</code> <code>yum makecache fast</code>

<code>$ </code><code>sudo</code> <code>yum </code><code>install</code> <code>docker-ce</code>

使用脚本自动安装

在测试或开发环境中 Docker 官方为了简化安装流程,提供了一套便捷的安装脚本,CentOS 系统上可以使用这套脚本安装:

<code>$ curl -fsSL get.docker.com -o get-docker.sh</code>

<code>$ </code><code>sudo</code> <code>sh get-docker.sh --mirror Aliyun</code>

执行这个命令后,脚本就会自动的将一切准备工作做好,并且把 Docker CE 的 edge 版本安装在系统中。

启动 Docker CE

<code>$ </code><code>sudo</code> <code>systemctl </code><code>enable</code> <code>docker</code>

<code>$ </code><code>sudo</code> <code>systemctl start docker</code>

查看 docker 详细信息

<code>[root@localhost ~]</code><code># docker info</code>

<code>Containers: 0</code>

<code> </code><code>Running: 0</code>

<code> </code><code>Paused: 0</code>

<code> </code><code>Stopped: 0</code>

<code>Images: 0</code>

<code>Server Version: 17.12.0-ce</code>

<code>Storage Driver: overlay2</code>

<code> </code><code>Backing Filesystem: xfs</code>

<code> </code><code>Supports d_type: </code><code>true</code>

<code> </code><code>Native Overlay Diff: </code><code>false</code>

<code>Logging Driver: json-</code><code>file</code>

<code>Cgroup Driver: cgroupfs</code>

<code>Plugins:</code>

<code> </code><code>Volume: </code><code>local</code>

<code> </code><code>Network: bridge host macvlan null overlay</code>

<code> </code><code>Log: awslogs fluentd gcplogs gelf journald json-</code><code>file</code> <code>logentries splunk syslog</code>

<code>Swarm: inactive</code>

<code>Runtimes: runc</code>

<code>Default Runtime: runc</code>

<code>Init Binary: docker-init</code>

<code>containerd version: 89623f28b87a6004d4b785663257362d1658a729</code>

<code>runc version: b2567b37d7b75eb4cf325b77297b140ea686ce8f</code>

<code>init version: 949e6fa</code>

<code>Security Options:</code>

<code> </code><code>seccomp</code>

<code>  </code><code>Profile: default</code>

<code>Kernel Version: 3.10.0-514.el7.x86_64</code>

<code>Operating System: CentOS Linux 7 (Core)</code>

<code>OSType: linux</code>

<code>Architecture: x86_64</code>

<code>CPUs: 2</code>

<code>Total Memory: 1.938GiB</code>

<code>Name: localhost.localdomain</code>

<code>ID: VL4E:2LXO:JMNS:DUO5:I5NT:DP53:OOW5:JB2V:HHRM:5N3W:BWOL:AYKU</code>

<code>Docker Root Dir: </code><code>/var/lib/docker</code>

<code>Debug Mode (client): </code><code>false</code>

<code>Debug Mode (server): </code><code>false</code>

<code>Registry: https:</code><code>//index</code><code>.docker.io</code><code>/v1/</code>

<code>Labels:</code>

<code>Experimental: </code><code>false</code>

<code>Insecure Registries:</code>

<code> </code><code>127.0.0.0</code><code>/8</code>

<code>Live Restore Enabled: </code><code>false</code>

<code>docker 默认的存储驱动类型为devicemapper,docker-ce 默认的存储驱动类型为overlay2。</code>

建立 docker 用户组

默认情况下,docker 命令会使用 Unix socket 与 Docker 引擎通讯。而只有 root 用户和 docker 组的用户才可以访问 Docker 引擎的 Unix socket。出于安全考虑,一般 Linux 系统上不会直接使用 root 用户。因此,更好地做法是将需要使用 docker 的用户加入 docker 用户组。

建立 docker 组:

<code>$ </code><code>sudo</code> <code>groupadd docker</code>

将当前用户加入 docker 组:

<code>$ </code><code>sudo</code> <code>usermod</code> <code>-aG docker $USER</code>

养成不使用root账户的好习惯,如果需要root则使用sudo。

执行visudo命令后,找到 以下行:

<code># %wheel ALL=(ALL) NOPASSWD: ALL</code>

把行首的注释去掉并保存退出。

修改用户:

<code>$ </code><code>usermod</code> <code>-aG wheel,docker $USER</code>

镜像加速

鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,强烈建议安装 Docker 之后配置 国内镜像加速。

<code>$ curl -sSL https:</code><code>//get</code><code>.daocloud.io</code><code>/daotools/set_mirror</code><code>.sh | sh -s http:</code><code>//df98fb04</code><code>.m.daocloud.io </code>

<code>$ </code><code>sudo</code> <code>systemctl restart docker</code>

添加内核参数

默认配置下,如果在 CentOS 使用 Docker CE 看到下面的这些警告信息:

<code>WARNING: bridge-nf-call-iptables is disabled</code>

<code>WARNING: bridge-nf-call-ip6tables is disabled</code>

请添加内核配置参数以启用这些功能。

<code>$ </code><code>sed</code> <code>-i </code><code>'/net.bridge.bridge-nf-call-ip6tables/s/0/1/g'</code> <code>/usr/lib/sysctl</code><code>.d</code><code>/00-system</code><code>.conf</code>

<code>$ </code><code>sed</code> <code>-i </code><code>'/net.bridge.bridge-nf-call-iptables/s/0/1/g'</code> <code>/usr/lib/sysctl</code><code>.d</code><code>/00-system</code><code>.conf </code>

<code>或者:</code>

<code>$ </code><code>sudo</code> <code>tee</code> <code>-a </code><code>/etc/sysctl</code><code>.conf &lt;&lt;-EOF</code>

<code>net.bridge.bridge-nf-call-ip6tables = 1</code>

<code>net.bridge.bridge-nf-call-iptables = 1</code>

<code>EOF</code>

然后重新加载 sysctl.conf 即可

<code>$ </code><code>sudo</code> <code>sysctl -p</code>

卸载docker-ce

<code># Docker 旧版本</code>

<code>[root@localhost ~]</code><code># sudo yum remove docker \</code>

<code>&gt;                   docker-common \</code>

<code>&gt;                   docker-selinux \</code>

<code>&gt;                   docker-engine</code>

<code># Docker-CE 版本</code>

<code>[root@localhost ~]</code><code># sudo yum remove docker-ce </code>

<code>[root@localhost ~]</code><code># sudo rm -rf /var/lib/docker</code>

参考文档

<a href="https://docs.docker.com/install/linux/docker-ce/centos/" target="_blank">Docker 官方 CentOS 安装文档</a>

<a href="https://yq.aliyun.com/articles/110806" target="_blank">阿里云 Docker CE 安装镜像帮助</a>

<b>本文转自 dengaosky 51CTO博客,原文链接:http://blog.51cto.com/dengaosky/2066662,如需转载请自行联系原作者</b>