CentOS7非root用户离线安装Docker及常见问题总结、各种操作系统docker桌面程序下载地址

环境说明

1、安装用户有sudo权限

2、本文讲docker组件安装,不是桌面程序安装

3、本文讲离线安装,不是在线安装

4、目标机器是内网机器,与外部网络不连通

下载

1、下载离线安装包,并上传到$HOME/basic-tool 目录

下载地址:Index of linux/static/stable/x86_64/

我下的这个:

https://download.docker.com/linux/static/stable/x86_64/docker-27.5.1.tgz

理由:rpm的安装起来反而麻烦,缺这个库缺那个库的

Docker 的扩展功能包 (在离线安装包下载地址页面)

https://download.docker.com/linux/static/stable/x86_64/docker-rootless-extras-27.5.1.tgz
说明:"rootless" 通常指的是不需要 root 权限就能运行 Docker 的特性

安装

1、解压

bash 复制代码
cd $HOME/basic-tool

tar -xvf docker-27.5.1.tgz

2、安装

bash 复制代码
sudo cp docker/* /usr/bin/

3、注册docker.service服务

bash 复制代码
# 用vi就行了,vim用的刚装的机器上都没这命令

vi /etc/systemd/system/docker.service
css 复制代码
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target
[Service]
Type=notify
ExecStart=/usr/bin/dockerd --selinux-enabled=false --insecure-registry=127.0.0.1
ExecReload=/bin/kill -s HUP $MAINPID
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
TimeoutStartSec=0
Delegate=yes
KillMode=process
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
[Install]
WantedBy=multi-user.target

4、添加镜像加速(此步可选)

bash 复制代码
sudo mkdir -p /etc/docker
bash 复制代码
sudo tee /etc/docker/daemon.json <<-'EOF'
{
    "oom-score-adjust": -1000,
    "log-driver": "json-file",
    "log-opts": {
    "max-size": "20m",
    "max-file": "3"
    },
    "max-concurrent-downloads": 10,
    "max-concurrent-uploads": 10,
    "registry-mirrors": ["https://sto5ef1n.mirror.aliyuncs.com"],
    "storage-driver": "overlay2",
    "storage-opts": [
    "overlay2.override_kernel_check=true"
    ]
}
EOF

5、创建 Docker 组并添加(当前)用户

bash 复制代码
# 添加用户组 docker
sudo groupadd docker

# 添加用户
sudo usermod -aG docker $USER
# 等价于
# sudo usermod -aG docker xxx(当前用户名)

#更新用户组
newgrp docker    

6、启动 Docker 服务

bash 复制代码
sudo chmod 777 /etc/systemd/system/docker.service
sudo systemctl daemon-reload
sudo systemctl enable docker
sudo systemctl start docker

7、验证安装

bash 复制代码
systemctl status docker
docker -v
docker info

常见问题

1、执行docker命令时报权限错

bash 复制代码
[zhaoXXXXXX@GZXXX-PM153161 basic-tool]$ docker ps
Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: 
Get "http://%2Fvar%2Frun%2Fdocker.sock/v1.24/containers/json": 
dial unix /var/run/docker.sock: connect: permission denied

解决:更新用户组

bash 复制代码
#更新用户组
newgrp docker 

2、启动docker守护进程报错

bash 复制代码
[zhao****@GZ****-PM153160 ~]$ sudo systemctl restart docker
Job for docker.service failed because the control process exited with error code.
See "systemctl status docker.service" and "journalctl -xe" for details.

解决:配置文件语法问题。删除解析不了的配置

查看报错详细日志(一般能看到提示了配置文件具体哪行的语法错,不同的版本支持的配置参数有差异):

bash 复制代码
# 查看 docker 守护进程日志
journalctl -u docker.service

3、登陆(私有)镜像仓库报错

bash 复制代码
[zhao****@GZ****-PM153160 ~]$ docker login 10.130.***.106:30089
Username: admin
Password: 
Error response from daemon: Get "https://10.130.***.106:30089/v2/": tls: failed to verify certificate: x509: cannot validate certificate for 10.130.***.106 because it doesn't contain any IP SANs

解决:换成域名

bash 复制代码
[zhao***@GZ***-PM153160 ~]$ docker login harbor.***.com:30089
Username: admin
Password: 
WARNING! Your password will be stored unencrypted in /home/zhaozheng/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credential-stores

Login Succeeded

总结

因大部分文章都不完整,不是少这步就是少那步,本文章是作者看了网上多个文章后取其精华并完善整理而来。作者此贴已亲测并验证通过,请放心参考!

附件

附件一:创建linux用户

bash 复制代码
# 创建用户组(上面有执行过)
# groupadd docker -g 200

# 创建 docker 用户  第一个docker是分组名,第二个docker是用户名
sudo useradd -g docker docker
sudo usermod -aG docker docker

# 修改 docker 用户密码
passwd docker   

附件二:将docker添加到sudo用户列表

bash 复制代码
# 没错这里就是vi和sudo两命令连在一起,中间没有空格
visudo
bash 复制代码
# 最后一行添加,保存即刻生效
docker ALL=(ALL) NOPASSWD:ALL

附件三:docker desktop下载

docker桌面程序下载地址
https://www.docker.com/

附件四:rpm相关包下载地址

本文不需要用

https://download.docker.com/linux/centos/7/x86_64/stable/Packages/docker-ce-26.1.4-1.el7.x86_64.rpm

https://download.docker.com/linux/centos/7/x86_64/stable/Packages/containerd.io-1.6.33-3.1.el7.x86_64.rpm

policycoreutils-python安装(装docker-ce-selinux的依赖,本文不需要用)

policycoreutils-python-2.5-34.el7.x86_64.rpm

附件五:不采用rpm包的理由

rpm的安装起来缺这个库缺那个库的

bash 复制代码
[zhaoXXXXX@GZXXX-PM153161 basic-tool]$ sudo rpm -ivh containerd.io-1.6.33-3.1.el7.x86_64.rpm
warning: containerd.io-1.6.33-3.1.el7.x86_64.rpm: Header V4 RSA/SHA512 Signature, key ID 621e9f35: NOKEY
error: Failed dependencies:
        container-selinux >= 2:2.74 is needed by containerd.io-1.6.33-3.1.el7.x86_64
bash 复制代码
[zhaoXXXXX@GZXXX-PM153161 basic-tool]$ sudo rpm -ivh docker-ce-20.10.24-3.el7.x86_64.rpm
warning: docker-ce-20.10.24-3.el7.x86_64.rpm: Header V4 RSA/SHA512 Signature, key ID 621e9f35: NOKEY
error: Failed dependencies:
        container-selinux >= 2:2.74 is needed by docker-ce-3:20.10.24-3.el7.x86_64
        containerd.io >= 1.4.1 is needed by docker-ce-3:20.10.24-3.el7.x86_64
        docker-ce-cli is needed by docker-ce-3:20.10.24-3.el7.x86_64
        docker-ce-rootless-extras is needed by docker-ce-3:20.10.24-3.el7.x86_64
        libcgroup is needed by docker-ce-3:20.10.24-3.el7.x86_64
bash 复制代码
[zhaoXXXXX@GZXXX-PM153161 basic-tool]$ sudo rpm -ivh docker-ce-rootless-extras-20.10.24-3.el7.x86_64.rpm
warning: docker-ce-rootless-extras-20.10.24-3.el7.x86_64.rpm: Header V4 RSA/SHA512 Signature, key ID 621e9f35: NOKEY
error: Failed dependencies:
        docker-ce is needed by docker-ce-rootless-extras-0:20.10.24-3.el7.x86_64
        fuse-overlayfs >= 0.7 is needed by docker-ce-rootless-extras-0:20.10.24-3.el7.x86_64
        slirp4netns >= 0.4 is needed by docker-ce-rootless-extras-0:20.10.24-3.el7.x86_64
bash 复制代码
[zhaoXXXXX@GZXXX-PM153161 basic-tool]$ sudo rpm -ivh policycoreutils-python-2.5-34.el7.x86_64.rpm
warning: policycoreutils-python-2.5-34.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID f4a80eb5: NOKEY
error: Failed dependencies:
        audit-libs-python >= 2.1.3-4 is needed by policycoreutils-python-2.5-34.el7.x86_64
        checkpolicy is needed by policycoreutils-python-2.5-34.el7.x86_64
        libapol.so.4()(64bit) is needed by policycoreutils-python-2.5-34.el7.x86_64
        libapol.so.4(VERS_4.0)(64bit) is needed by policycoreutils-python-2.5-34.el7.x86_64
        libcgroup is needed by policycoreutils-python-2.5-34.el7.x86_64
        libqpol.so.1()(64bit) is needed by policycoreutils-python-2.5-34.el7.x86_64
        libqpol.so.1(VERS_1.2)(64bit) is needed by policycoreutils-python-2.5-34.el7.x86_64
        libqpol.so.1(VERS_1.4)(64bit) is needed by policycoreutils-python-2.5-34.el7.x86_64
        libselinux-python is needed by policycoreutils-python-2.5-34.el7.x86_64
        libsemanage-python >= 2.5-14 is needed by policycoreutils-python-2.5-34.el7.x86_64
        policycoreutils = 2.5-34.el7 is needed by policycoreutils-python-2.5-34.el7.x86_64
        python-IPy is needed by policycoreutils-python-2.5-34.el7.x86_64
        setools-libs >= 3.3.8-4 is needed by policycoreutils-python-2.5-34.el7.x86_64

附件六:iptables对外开放5151端口

bash 复制代码
sudo iptables -I INPUT -p tcp --dport 5151 -j ACCEPT
相关推荐
一起屠龙16 分钟前
SpringAi+MCP实现sse及stdio服务调用
docker·llm·mcp
RedCong30 分钟前
kubectl命令补全以及oc命令补全
云原生·kubernetes·kubectl命令补全
MUMUoO1 小时前
Windows平台上安装与使用Docker
docker
放情2 小时前
关于k8s的部署
java·docker·kubernetes
阿里云云原生4 小时前
AI 时代,为什么编程能力≠ 开发门槛
云原生
❀͜͡傀儡师4 小时前
Docker部署禅道21.6开源版本
运维·docker·容器
卷不动的打工仔5 小时前
Ubuntu利用docker搭建Java相关环境记录(二)
java·ubuntu·docker
wqq10275 小时前
docker Windows 存放位置
运维·docker·容器
卷不动的打工仔6 小时前
Ubuntu利用docker搭建Java相关环境问题记录
java·ubuntu·docker
孔令飞7 小时前
如何使用Docker在本地运行一个大模型?
人工智能·云原生·go