linux中使用docker命令时提示权限不足

问题:成功安装docker后,使用docker相关命令时提示权限不足(permission denied)

bash 复制代码
liubai@liubai:~$ docker version
Client:
Version: 24.0.5
API version: 1.43
Go version: go1.20.14
Git commit: ced0996
Built: Tue Jun 25 22:37:33 2024
OS/Arch: linux/amd64
Context: default
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/version": dial unix /var/run/docker.sock: connect: permission denied

解决:这通常是由于运行docker命令的用户没有足够的权限访问docker.sock\docker\snap.docker所导致的,当为该情况时可按照如下方法修改权限

1、检查docker用户组是否存在

bash 复制代码
cat /etc/group | grep docker

使用该命令查看用户组文件中是否包含docker用户组的相关信息,如果无返回则不存在docker用户组。如下为存在时的返回:

bash 复制代码
liubai@liubai:~$ cat /etc/group | grep docker
docker:x:1001:liubai
1.1、如果不存在则创建docker用户组,存在则下一步
bash 复制代码
sudo groupadd docker

使用该命令创建名为docker的用户组,可使用前面的命令查看是否创建成功。

1.2、检查需要使用docker的用户是否存在于docker用户组中
bash 复制代码
sudo groups liubai

使用该命令查看用户liubai所属的用户组,一般会返回多个用户组,检查其中是否包含docker,包含时的返回为:

bash 复制代码
liubai@liubai:~$ groups liubai
liubai : liubai adm cdrom sudo dip plugdev lxd docker
1.3、如果用户(liubai)不属于docker用户组,希望添加则使用如下命令
bash 复制代码
sudo gpasswd -a liubai docker

2、如果确认docker用户组存在,且需要使用docker的用户存在于docker用户组中,那么需要检查docker\docker.sock\snap.docker的权限归属情况。

bash 复制代码
ls -l /var/run/docker
ls -l /var/run/docker.sock
ls -l /var/run/snap.docker

通常会发现,他们的权限归属全为root,形如

bash 复制代码
liubai@liubai:~$ ls -l /var/run/docker.sock
srw-rw---- 1 root root 0 Sep 29 12:40 /var/run/docker.sock

当发现这种情况时,请分别修改三个文件的所属组(而不修改其所属主),使用如下命令

bash 复制代码
sudo chown root:docker /var/run/docker
sudo chown root:docker /var/run/docker.sock 
sudo chown root:docker /var/run/snap.docker

再次确认权限归属情况时,返回应该形如:

bash 复制代码
liubai@liubai:~$ ls -l /var/run/docker.sock
srw-rw---- 1 root docker 0 Sep 29 12:40 /var/run/docker.sock

修改后可以尝试使用docker命令,应该已经解决权限不足问题。

如果仍然提示权限不足,可能存在的原因:1、用户组绑定未成功(请登出该用户后重新登录)2、docker守护进程或docker本身未成功加载修改(请重启docker守护进程或docker本身)

3、重启docker守护进程或重启docker本身

bash 复制代码
#重启docker的守护进程
sudo systemctl reload docker

#重启docker服务当重启守护进程后权限仍未生效时
sudo systemctl restart docker
相关推荐
kebidaixu1 小时前
BCU 平台 RS485 驱动适配:从 THVD1406 到 ISO3082
linux
杨浦老苏1 小时前
家庭实验室监控仪表盘HomeLab-Monitor
运维·docker·监控·群晖
谢平康3 小时前
解决用 rm 报bash: /usr/bin/rm: Argument list too long错
linux·运维·运维开发
hj2862515 小时前
Linux 网络服务综合笔记(概念 + 命令 + 实操案例)2
linux·运维·网络
what_20185 小时前
Linux 磁盘 (查看、划分、inode)
linux·运维·服务器
2739920295 小时前
GDB调试(Linux)
linux
ai产品老杨6 小时前
架构师深剖:基于 Docker 容器化与边缘计算的 AI 视频管理平台——支持 GB28181/RTSP 多协议接入与全源码交付
人工智能·docker·边缘计算
凡人叶枫6 小时前
Effective C++ 条款23:宁以 non-member、non-friend 替换 member 函数
linux·开发语言·c++·嵌入式开发
不会C语言的男孩6 小时前
Linux 系统编程 · 第 4 章:文件属性与元数据
linux·c语言·开发语言
小生不才yz6 小时前
Shell脚本精读 · S02-03 | 词拆分、通配符与未加引号的变量
linux