docker命令中必须加上sudo的问题解决方法
目录
- 1、问题背景
- 2、问题原因
- 3、解决方法
- Attention
1、问题背景
初次使用docker时,安装后通过终端进行docker命令时必须加上root权限,否则将会报错,如下所示:

问题原因和相应的解决方法在官方网站中有文档解释:
https://docs.docker.com/engine/install/linux-postinstall/
2、问题原因
docker提供服务的后台守护进程是绑定至一个Unix socket上而非TCP端口上,而通常这个Unix socket只能由root用户使用,普通权限的用户使用时必须加上 sudo 命令
3、解决方法
知道原因以后,解决方法就显而易见了:让当前用户有使用Unix socket的权限具体做法是创建一个名叫 docker 的Unix用户组,并且把当前用户添加进去,当docker守护进程启动创建Unix socket时就会自动令该组下的所有成员能够进行访问
sudo groupadd docker sudo usermod -aG docker $USER #此处的USER是系统变量,直接使用该语句即可 newgrp docker
通过上述方法可能会令当前用户拥有root权限,所以应当谨慎使用,具体风险如下:
https://docs.docker.com/engine/security/#docker-daemon-attack-surface
大家可以看一看官方文档,里面也列举了可能会遇到的其他问题
Attention
虽然这样做可以在输入docker命令时不用加sudo,但并非对于所有命令都有效,如:
docker login ... or docker push ...
如果使用上述方法后执行docker命令发现奇怪的报错,可以先使用sudo再尝试执行一次
您可能感兴趣的文章
- 01-07Tomcat部署Bolo动态博客
- 01-07图文详解nginx日志切割的实现
- 01-07如何解决swarm docker 端口不通问题
- 01-07详解nginx location指令
- 01-07如何解决docker http 500错误问题
- 01-07windows server 2008安装配置DNS服务器
- 01-07Linux上搭载Nginx负载均衡配置使用案例详解
- 01-07NGINX 权限控制文件预览和下载的实现原理
- 01-07Nginx防盗链与服务优化配置的全过程
- 01-07使用 Apache 反向代理的设置技巧


阅读排行
推荐教程
- 12-23linux中ftp无法访问怎么办
- 12-11docker存储目录迁移示例教程
- 12-10docker start启动容器后仍然exit状态的解决
- 12-10Linux下如何安装Logstash
- 01-05Shell脚本去重的几种方法实例
- 12-22kvm虚拟机配置NAT端口转发的实现方法
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-14Docker Desktop无法正常启动解决(failed to start...)
- 12-14k8s 与docker空间使用分析与清理方法




