如何 让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,既方便又相对安全。

相关推荐
光电的一只菜鸡7 小时前
ubuntu之坑(十九)——VMware虚拟机扩容磁盘
linux·数据库·ubuntu
格林威9 小时前
Linux使用-Linux系统管理
linux·运维·服务器·深度学习·ubuntu·计算机视觉
周小码9 小时前
Go开发的自行托管代理加速服务:支持Docker与GitHub加速
docker·golang·github
川石课堂软件测试9 小时前
Oracle 数据库使用事务确保数据的安全
数据库·python·功能测试·docker·oracle·单元测试·prometheus
奋斗的老史10 小时前
25年Docker镜像无法下载的四种对策
docker·容器·eureka
小马爱打代码10 小时前
Spring Cloud Eureka 核心原理
spring cloud·eureka
chillxiaohan10 小时前
Docker学习记录
学习·docker·容器
柯南二号10 小时前
【后端】Docker 常用命令详解
服务器·nginx·docker·容器
一匹电信狗11 小时前
【Linux我做主】细说进程等待
linux·运维·服务器·c++·ubuntu·小程序·开源
我今天指定是不行了12 小时前
Docker安装与部分应用安装
docker