如何 让ubuntu 在root 下安装的docker 在 普通用户下也能用

在 Ubuntu 系统中,如果 Docker 是以 root 用户安装的,普通用户默认无法直接使用 Docker 命令(会报权限错误)。要让普通用户也能使用 Docker,可以按照以下步骤操作:


方法 1:将用户加入 docker 用户组(推荐)

Docker 安装时会自动创建一个名为 docker 的用户组,将普通用户加入该组即可获得权限。

  1. 创建 docker 用户组(如果尚未存在)

    bash 复制代码
    sudo groupadd docker
  2. 将当前用户加入 docker

    bash 复制代码
    sudo usermod -aG docker $USER
    • $USER 是当前用户名,也可以替换为目标用户名(如 sudo usermod -aG docker username)。
  3. 刷新用户组权限

    • 退出当前终端并重新登录,或者运行以下命令立即生效:

      bash 复制代码
      newgrp docker
  4. 验证是否生效

    bash 复制代码
    docker run hello-world
    • 如果成功运行,说明配置正确。

方法 2:直接修改 Docker 的权限(不推荐)

如果不想将用户加入 docker 组,可以临时修改 Docker 套接字文件的权限(但存在安全风险):

bash 复制代码
sudo chmod 666 /var/run/docker.sock
  • 注意:这会允许所有用户访问 Docker,可能导致提权漏洞,仅建议在测试环境使用。

方法 3:通过 sudo 运行 Docker 命令

如果不想配置用户组,可以在每条 Docker 命令前加 sudo

bash 复制代码
sudo docker ps
  • 也可以通过 visudo 配置免密码 sudo 权限,但同样存在安全风险。

补充说明

  1. 安全提醒

    • docker 用户组实际上拥有与 root 等效的权限(因为 Docker 守护进程以 root 运行)。仅将受信任的用户加入该组。
    • 生产环境中建议结合 Docker 的 TLS 认证或细粒度授权插件(如 authz)进行权限控制。
  2. 如果 docker 组不存在

    • 可能是 Docker 未正确安装。重新安装 Docker:

      bash 复制代码
      sudo apt update
      sudo apt install docker.io
  3. 持久化配置

    • 上述方法 1 的配置是永久生效的,重启后无需重复操作。

通过以上步骤,普通用户即可无需 sudo 直接使用 Docker 命令。推荐使用 方法 1,既方便又相对安全。

相关推荐
qq_317620311 天前
06:Docker安全加固与性能优化
docker·性能优化·权限控制·安全加固·镜像扫描
java_logo1 天前
ComfyUI Docker 镜像部署指南
运维·docker·容器·comfyui部署·docker部署comfyui·comfyui部署文档·comfyui部署教程
眠りたいです1 天前
docker-compose:使用docker-compose对多容器应用进行管理并进行wordpress简单站点的搭建
运维·nginx·docker·容器·wordpress·busybox
hgz07101 天前
Docker
docker
qq_317620311 天前
05:Docker练习项目
docker·微服务架构·大数据平台·监控系统·devops工具链
学不完的路路路1 天前
IMX6ULL开发板固件烧录问题:添加设备树节点不成功
linux·ubuntu·设备树
oMcLin1 天前
Ubuntu 22.04 Docker 容器启动失败:解决 Overlay2 存储驱动冲突
java·ubuntu·docker
幺零九零零1 天前
Windows + Docker + k6 + InfluxDB + Grafana
windows·docker·grafana
qq_317620311 天前
01:Docker 概述
运维·docker·容器·docker安装
知识分享小能手1 天前
Ubuntu入门学习教程,从入门到精通, Ubuntu 22.04中的进程管理详解(15)
linux·学习·ubuntu