一、安装Docker CE
卸载旧版本
较旧版本的Docker
被称为docker
或docker-engine
。如果已安装这些,需要卸载以及相关的依赖项。
$ sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-selinux \
docker-engine-selinux \
docker-engine
安装Docker CE
您可以根据需要以不同方式安装Docker CE:
- 大多数用户设置Docker的仓库并从中进行安装,以便于安装和升级任务。这是推荐的方法。
- 有些用户下载RPM软件包并手动安装并完全手动管理升级。这在没有访问互联网的系统上安装Docker的情况下非常有用。
- 在测试和开发环境中,一些用户选择使用自动便捷脚本来安装Docker。
使用仓库安装
在新主机上首次安装Docker CE
之前,需要设置Docker
仓库。之后,您可以从仓库安装和更新Docker
。
设置存储库
-
安装所需的包。
yum-utils
提供yum-config-manager
实用程序,devicemapper
存储驱动程序需要device-mapper-persistent-data
和lvm2
。$ sudo yum install -y yum-utils \ device-mapper-persistent-data \ lvm2
-
设置稳定存储库。
使用以下命令设置稳定存储库
$ sudo yum-config-manager \ --add-repo \ https://download.docker.com/linux/centos/docker-ce.repo
可选:启用
edge
和test
存储库。这些存储库包含在上面的docker.repo
文件中,但默认情况下处于禁用状态。您可以将它们与稳定存储库一起启用。$ sudo yum-config-manager --enable docker-ce-edge
$ sudo yum-config-manager --enable docker-ce-test
通过使用
--disable
标志运行yum-config-manager
命令来禁用edge
或test
仓库。要重新启用,使用--enable
标志。以下命令禁用edge
仓库。$ sudo yum-config-manager --disable docker-ce-edge
注意:从Docker 17.06开始,稳定版本也会被推送到边缘并测试存储库。
安装DOCKER CE
-
安装最新版本
安装最新版本的
Docker CE
,或转到下一步安装特定版本:$ sudo yum install docker-ce
如果提示接受GPG密钥,请确认指纹符合
060A 61C5 1B55 8A7F 742B 77AA C52F EB6B 621E 9F35
,如果符合,则接受该指纹。运行以上命令安装后,
Docker
已安装但尚未启动。并已创建docker
组,但未向该组添加任何用户。 -
安装特定版本
-
要安装特定版本的
Docker CE
,可列出repo
中的可用版本,然后选择并安装$ yum list docker-ce --showduplicates | sort -r docker-ce.x86_64 18.06.1.ce-3.el7 docker-ce-stable docker-ce.x86_64 18.06.0.ce-3.el7 docker-ce-stable docker-ce.x86_64 18.03.1.ce-1.el7.centos docker-ce-stable docker-ce.x86_64 18.03.0.ce-1.el7.centos docker-ce-stable
返回的列表取决于启用的仓库,并且特定于您的
CentOS
版本(在此示例中以.el7
后缀表示CentOS7
)。 -
通过其完全限定的包名称安装特定版本
包名称(docker-ce)加上版本字符串(第2列),中间用连字符( - )分隔,
例如,
docker-ce-18.06.1.ce
$ sudo yum install docker-ce-18.06.1.ce
运行以上命令安装后,
Docker
已安装但尚未启动。并已创建docker
组,但未向该组添加任何用户。
-
启动测试Docker
-
启动
Docker
$ sudo systemctl start docker
-
通过运行
hello-world
映像验证是否正确安装了docker。$ sudo docker run hello-world
此命令下载
hello-world
镜像并在容器中运行它。当容器运行时,它会打印消息并退出。如果网络下载失败,可能需要配置国内加速器,或者需要使用代理连接,可以通过下面的Linux安装后配置进行配置
升级DOCKER CE
要升级Docker CE,选择特定版本安装新版本或选择安装最新版本。
使用包安装
如果您无法使用Docker
存储库来安装Docker
,可以下载适用于您的发行版的.rpm
文件并手动安装。每次要升级Docker
时都需要下载新文件。
安装Docker CE
-
CentOS
-
转到https://download.docker.com/linux/centos/7/x86_64/stable/Packages/并下载要安装的
Docker
版本的.rpm
文件。注意:要安装
edge
或test
包,请将上述URL中的单词stable
更改为edge
或test
。 -
安装
Docker CE
,将下面的路径更改为Docker
软件包的路径。如
Docker
的``docker.rpm`包在用户主目录下$ sudo yum install ~/docker.rpm
Docker
已安装但尚未启动。已创建docker
组,但未向该组添加任何用户。
-
升级DOCKER CE
要升级Docker CE
,请下载较新的软件包文件并重复安装过程,使用yum -y upgrade
,而不是yum -y install
,并指向新软件包。
卸载 Docker CE
卸载Docker包:
$ sudo yum remove docker-ce
主机上的图像,容器,卷或自定义配置文件不会自动删除。
要删除所有图像,容器和卷:
$ sudo rm -rf /var/lib/docker
二、Docker安装后配置
HTTP/HTTPS代理
如果您使用HTTP
或HTTPS
代理服务器,例如在公司设置中,您需要在Docker systemd service
文件中添加此配置。
-
为Docker服务创建一个 systemd多级目录:
$ sudo mkdir -p /etc/systemd/system/docker.service.d
-
创建一个名为
/etc/systemd/system/docker.service.d/http-proxy.conf
的文件。添加HTTP_PROXY
环境变量:[Service] Environment="HTTP_PROXY=http://username:password@0.0.0.1:80/"
或者,如果您在HTTPS代理服务器后面,创建一个名为
/etc/systemd/system/docker.service.d/https-proxy.conf
的文件,添加HTTPS_PROXY环境变量:[Service] Environment="HTTPS_PROXY=https://username:password@0.0.0.1:80/"
-
如果您有自己的私有Docker仓库,而无需代理,您可以通过
NO_PROXY
环境变量指定它们:[Service] Environment="HTTP_PROXY=http://username:password@0.0.0.1:80/" "NO_PROXY=localhost,127.0.0.1,docker-registry.somecorporation.com"
或者, 如果您在 HTTPS 代理服务器后面添加:
[Service] Environment="HTTPS_PROXY=https://username:password@0.0.0.1:80/" "NO_PROXY=localhost,127.0.0.1,docker-registry.somecorporation.com"
-
刷新更改:
$ sudo systemctl daemon-reload
-
重启Docker:
$ sudo systemctl restart docker
-
验证配置已经加载:
$ systemctl show --property=Environment docker Environment=HTTP_PROXY=http://username:password@0.0.0.1:80/
或者:
$ systemctl show --property=Environment docker Environment=HTTPS_PROXY=https://username:password@0.0.0.1:80/
以非root身份管理Docker
Docker daemon
绑定到Unix socket
而不是TCP
端口。默认情况下,Unix socket
由用户root
拥有,而其他用户只能使用sudo
访问它。 Docker daemon
始终以root
用户身份运行。
如果您不想在docker
命令前加上sudo
,可以创建一个名为docker
的Unix
组并向其添加用户。当Docke
启动时,它会创建一个可由docker
组成员访问的Unix socket
。
警告
docker组授予与root用户等效的权限。
有关这将如何影响系统安全性的详细信息,请参阅Docker Daemon Attack Surface。
要创建docker组并添加您的用户:
-
创建docker组
$ sudo groupadd docker
-
将您的用户添加到docker组
$ sudo usermod -aG docker $USER
-
注销并重新登录,以便您的组成员身份生效。
-
验证您是否可以在没有
sudo
的情况下运行docker
命令.$ docker run hello-world
如果容器运行,它会打印消息并退出,说明设置生效
如果在将用户添加到
docker
组之前最初使用sudo
运行Docker CLI
命令,则可能会看到以下错误,这表示由于sudo
命令而创建的〜/.docker/
目录的权限不正确。WARNING: Error loading config file: /home/user/.docker/config.json - stat /home/user/.docker/config.json: permission denied
要解决此问题,请删除
〜/.docker/
目录(它会自动重新创建,但任何自定义设置都将丢失),或使用以下命令更改其所有权和权限:$ sudo chown "$USER":"$USER" /home/"$USER"/.docker -R $ sudo chmod g+rwx "$HOME/.docker" -R
镜像加速
由于Docker Hub
的服务器在国外,镜像的下载速度比较慢,可以使用国内提供的免费镜像服务,国内免费镜像服务有阿里云和DaoCloud等有提供:
-
阿里云
- 注册登录后,进入控制台,在产品与服务中搜索容器镜像服务进入,在镜像加速器有阿里云提供给个人的加速器地址
- 按照操作文档选择对应的服务器类型操作,
-
DaoCloud
-
注册登录后,点击加速器图标
-
进入页面后,复制内容到Shell终端运行
-
随系统启动而启动
-
systemd
开启随系统启动
$ sudo systemctl enable docker
关闭随系统启动,改用disable。
$ sudo systemctl disable docker
查看状态
$ sudo systemctl is-enabled docker