背景说明
操作系统版本,红帽RHEL9版本
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
[root@localhost ~]# cat /etc/os-release
NAME="Red Hat Enterprise Linux"
VERSION="9.5 (Plow)"
ID="rhel"
ID_LIKE="fedora"
VERSION_ID="9.5"
PLATFORM_ID="platform:el9"
PRETTY_NAME="Red Hat Enterprise Linux 9.5 (Plow)"
ANSI_COLOR="0;31"
LOGO="fedora-logo-icon"
CPE_NAME="cpe:/o:redhat:enterprise_linux:9::baseos"
HOME_URL="https://www.redhat.com/"
DOCUMENTATION_URL="https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/9"
BUG_REPORT_URL="https://issues.redhat.com/"
REDHAT_BUGZILLA_PRODUCT="Red Hat Enterprise Linux 9"
REDHAT_BUGZILLA_PRODUCT_VERSION=9.5
REDHAT_SUPPORT_PRODUCT="Red Hat Enterprise Linux"
REDHAT_SUPPORT_PRODUCT_VERSION="9.5"
|
1、安装EPEL存储库
首先执行命令sudo yum install epel-release -y
进行安装,-y
参数会自动安装,安装过程中无需手动敲y
可能会出现找不到匹配的软件包
1
2
3
4
5
|
[root@localhost ~]# sudo yum install epel-release -y
Updating Subscription Management repositories.
Last metadata expiration check: 2:16:32 ago on Mon 13 Jan 2025 07:12:38 PM CST.
No match for argument: epel-release
Error: Unable to find a match: epel-release
|
解决方法:
启用EPEL存储库,需要安装yum-utils
软件包,然后使用yum-config-manager
命令启用EPEL存储库,执行以下命令:
1
2
|
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
sudo yum-config-manager --enable epel
|
然后再尝试安装epel-release
软件包,执行以下命令
1
2
3
4
|
sudo yum install epel-release
# 注:如果该条命令依旧显示无法找到匹配的软件包,可以尝试使用以下命令(个人是使用这个命令执行成功的)
# sudo yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm
|
安装epel-release
后,更新系统包缓存,执行以下命令
1
2
3
|
sudo yum clean all
sudo yum makecache
sudo yum update
|
2、设置docker的yum源
执行以下命令,在yum中添加docker源
1
|
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
|
3、安装docker
在正式安装docker之前,如果当前主机中安装的有旧版docker或者不是docker-ce的版本,先进行卸载,执行命令
1
2
3
4
5
6
7
8
|
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
|
开始安装docker-ce
、docker-ce-cli
、containerd.io
,执行以下命令
1
|
sudo yum install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
|
然后等待完成安装即可
4、docker配置文件
使用vi/vim
编辑vim /etc/systemd/system/docker.service
文件,将以下内容写入该文件中
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
BindsTo=containerd.service
After=network-online.target firewalld.service containerd.service
Wants=network-online.target
Requires=docker.socket
[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
ExecReload=/bin/kill -s HUP $MAINPID
TimeoutSec=0
RestartSec=2
Restart=always
# Note that StartLimit* options were moved from "Service" to "Unit" in systemd 229.
# Both the old, and new location are accepted by systemd 229 and up, so using the old location
# to make them work for either version of systemd.
StartLimitBurst=3
# Note that StartLimitInterval was renamed to StartLimitIntervalSec in systemd 230.
# Both the old, and new name are accepted by systemd 230 and up, so using the old name to make
# this option work for either version of systemd.
StartLimitInterval=60s
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Comment TasksMax if your systemd version does not support it.
# Only systemd 226 and above support this option.
TasksMax=infinity
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
[Install]
WantedBy=multi-user.target
|
使用vi/vim
编辑vim /etc/systemd/system/docker.socket
文件,将以下内容写入该文件中
1
2
3
4
5
6
7
8
9
10
11
12
|
[Unit]
Description=Docker Socket for the API
PartOf=docker.service
[Socket]
ListenStream=/run/docker.sock
SocketMode=0660
SocketUser=root
SocketGroup=root
[Install]
WantedBy=sockets.target
|
5、配置docker的daemon.json
首先登陆阿里云账号,阿里云地址:https://cn.aliyun.com/
,找到并点击控制台
,然后搜索:容器镜像服务。点击进入


然后编辑文件vim /etc/docker/daemon.json
,将以下内容写入你的daemon.json文件中
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
{
"dns": ["8.8.8.8", "8.8.4.4"],
"registry-mirrors": [
"https://你的阿里云镜像加速地址", // 注:该行自行添加你自己阿里云的镜像加速地址
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com",
"https://docker.mirrors.ustc.edu.cn",
"https://omh8vcpy.mirror.aliyuncs.com",
"https://docker.m.daocloud.io/",
"https://huecker.io/",
"https://dockerhub.timeweb.cloud",
"https://noohub.ru/",
"https://dockerproxy.com",
"https://docker.mirrors.ustc.edu.cn",
"https://docker.nju.edu.cn",
"https://xx4bwyg2.mirror.aliyuncs.com",
"http://f1361db2.m.daocloud.io",
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com",
"https://docker.mirrors.ustc.edu.cn"
]
}
|
然后重新加载守护进程,执行命令sudo systemctl daemon-reload
6、启动docker
启动docker
1
|
sudo systemctl start docker
|
至此docker安装完毕,并且启动成功
7、docker其他相关命令
重启docker服务
1
|
sudo systemctl restart docker
|
拉取docker镜像,既然是软件,那么怎么能少的了我们的HelloWorld
呢,此处就以拉取hello-world
镜像为例,执行命令docker pull 你要拉取的镜像名及版本包
,注:若没有版本号,那么拉取的就是最新的(latest)版本
1
|
docker pulll hello-world
|
查看docker已拉取下来的镜像有哪些