当前位置: 首页 > news >正文

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

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


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

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

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

    sudo groupadd docker
    
  2. 将当前用户加入 docker

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

    • 退出当前终端并重新登录,或者运行以下命令立即生效:
      newgrp docker
      
  4. 验证是否生效

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

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

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

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

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

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

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

补充说明

  1. 安全提醒

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

    • 可能是 Docker 未正确安装。重新安装 Docker:
      sudo apt update
      sudo apt install docker.io
      
  3. 持久化配置

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

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

http://www.dtcms.com/a/321116.html

相关文章:

  • Spring Boot 结合 CORS 解决前端跨域问题
  • GitLab同步提交的用户设置
  • 2025年渗透测试面试题总结-08(题目+回答)
  • 【19】C#实战篇—— C# 绘制点划线,绘制虚线——PointF dxdy,过x点垂直画红色点划线,长度为W,过y点水平画红色点划线,长度为H
  • 华清远见25072班C语言学习day5
  • 自动驾驶数据闭环
  • 进程管理、系统高负载、cpu超过800%等实战问题处理
  • 机器人权利:虚实之间的伦理与法理探界
  • F5发布业界首创集成式应用交付与安全平台,开启ADC 3.0新时代
  • 【Oracle Linux 9.6】切换默认为命令行模式
  • git如何使用和操作命令?
  • 【/usr/bin/env: “bash\r”: 没有那个文件或目录】问题解决
  • C# GUI程序中的异步操作:解决界面卡顿的关键技术
  • 【C++动态版本号生成方案:实现类似C# 1.0.* 的自动构建号】
  • Ubuntu 系统本地部署 Dify 完整教程
  • MySQL查询语句(会持续更新)
  • Dart关键字完全指南:从基础到高级用法详解
  • [GESP202309 五级] 2023年9月GESP C++五级上机题题解,附带讲解视频!
  • 《Git从入门到精通:告别版本管理混乱》
  • Git 工程迁移指南
  • 如何在 Ubuntu 24.04 LTS 或 22.04/20.04 上安装 Apache Maven
  • ORACLE物化视图快速刷新失败原因查找
  • Oracle 的 exp(传统导出工具)和 expdp(Data Pump 导出工具)是两种命令对比
  • Python合并两个PDF文件
  • 汽车专题 | 视觉AI正在重构整车质检格局
  • OpenAPI(Swagger3)接口文档自定义排序(万能大法,支持任意swagger版本)
  • 基于AI MCP协议, 写一个MCP服务用于连接数据库执行sql
  • PostgreSQL技术大讲堂 - 第100讲:玩转PG数据库对象权限卷之迷宫
  • Langchain入门:构建一个基于SQL数据的问答系统
  • DM8数据库服务正常,但是登录报错 [-70019]:没有匹配的可登录服务器