警告:切勿在没有配置 Docker YUM 源的情况下直接使用 yum 命令安装 Docker,如果直接使用yum install docker命令安装,安装的docker是旧版本的
1. 准备工作
1.1 系统要求
Docker CE 支持 64 位版本 CentOS 7,并且要求内核版本不低于 3.10。 CentOS 7 满足最低内核的要求,但由于内核版本比较低,部分功能(如 overlay2 存储层驱动)无法使用,并且部分功能可能不太稳定。
使用如下命令查看:
uname -r
1.2 卸载旧版本
旧版本的 Docker 称为 docker 或者 docker-engine,使用以下命令卸载旧版本:
yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-selinux docker-engine-selinux docker-engine
2. 使用 yum 安装
执行以下命令安装依赖包:
yum install -y yum-utils device-mapper-persistent-data lvm2
执行下面的命令添加 yum 软件源:
鉴于国内网络问题,强烈建议使用国内源,官方源见注释
yum-config-manager --add-repo https://mirrors.ustc.edu.cn/docker-ce/linux/centos/docker-ce.repo
# 官方源
# yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
如果需要最新版本的 Docker CE 请使用以下命令:
yum-config-manager --enable docker-ce-edge
如果需要测试版本的 Docker CE 请使用以下命令:
yum-config-manager --enable docker-ce-test
安装 Docker CE
更新 yum 软件源缓存,并安装 docker-ce。
# 更新软件缓存
yum makecache fast
# 安装docker
yum install -y docker-ce
3. 使用脚本自动安装
在测试或开发环境中 Docker 官方为了简化安装流程,提供了一套便捷的安装脚本,CentOS 系统上可以使用这套脚本安装:
# 下载脚本
curl -fsSL get.docker.com -o get-docker.sh
# 执行脚本
sh get-docker.sh --mirror Aliyun
执行这个命令后,脚本就会自动的将一切准备工作做好,并且把 Docker CE 的 Edge 版本安装在系统中。
4. 启动 Docker CE
# docker开机启动
systemctl enable docker
# 启动docker
systemctl start docker
5. 建立 docker 用户组(非root用户情况下)
默认情况下,docker 命令会使用 Unix socket 与 Docker 引擎通讯。而只有 root 用户和 docker 组的用户才可以访问 Docker 引擎的 Unix socket。出于安全考虑,一般 Linux 系统上不会直接使用 root 用户。因此,更好地做法是将需要使用 docker 的用户加入 docker 用户组。
# 建立docker组
sudo groupadd docker
# 将当前用户加入docker组
sudo usermod -aG docker $USER
退出当前终端并重新登录,进行如下测试。
6. 测试Docker是否安装正确
docker info
若能正常输出信息,则说明安装成功。
7.卸载Docker
删除docker安装包
yum remove docker-ce
删除docker镜像
rm -rf /var/lib/docker
8. 配置镜像加速
鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,强烈建议安装 Docker 之后配置 国内镜像加速。
对于使用systemd的系统,请在/etc/docker/daemon.json中写入如下内容(如果文件不存在则新建该文件)
{
"registry-mirrors":[
"http://hub-mirror.c.163.com"
]
}
重新启动服务生效
# 重新载入配置
systemctl daemon-reload
# 重启docker
systemctl restart docker
验证镜像是否修改成功
docker info | grep -A 1 Mirrors
如果修改成功,即可看到配置的镜像链接。
9. 添加内核参数(非必须)
默认配置下,如果在 CentOS 使用 Docker CE 看到下面的这些警告信息:
WARNING: bridge-nf-call-iptables is disabled
WARNING: bridge-nf-call-ip6tables is disabled
请添加内核配置参数以启用这些功能。
tee -a /etc/sysctl.conf <<-EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
然后重新加载 sysctl.conf 即可
sysctl -p