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

如何让非 root 用户构建 Docker 镜像

如何让非 root 用户构建 Docker 镜像

  • 前言
  • 方法 1:将用户加入 Docker 组(推荐)
  • 方法 2:使用 sudo 运行 Docker(不推荐)
  • 方法 3:使用 Docker Rootless 模式
  • 总结


前言

在默认情况下,Docker 需要 root 权限或 sudo 才能运行。这对于日常开发和 CI/CD 流水线可能不够方便,也可能带来安全隐患。那么,如何让 非 root 用户 也能构建和运行 Docker 容器呢?

本篇文章将介绍 三种方法 来实现这一目标,并推荐最佳实践。


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

Docker 允许 docker 组的用户运行 Docker 命令,因此最简单的方法是将你的用户加入 docker 组。

  1. 创建 Docker 组(如果不存在)

    sudo groupadd docker
    
  2. 将用户加入 Docker 组

    sudo usermod -aG docker $USER
    

    如果你要添加其他用户,替换 $USER 为具体的用户名:

    sudo usermod -aG docker your-username
    
  3. 重新登录使权限生效

    执行以下命令让组权限立即生效,或者注销并重新登录:

    newgrp docker
    
  4. 测试是否生效

    docker ps
    

如果能正确输出 Docker 运行中的容器列表,而 不需要 sudo,则说明配置成功。

方法 2:使用 sudo 运行 Docker(不推荐)

如果你不想修改用户组,可以在每次执行 Docker 命令时使用 sudo

sudo docker build -t myimage .

但这样使用起来不方便,并且某些 CI/CD 或自动化脚本可能不兼容 sudo,所以 不推荐 这种方式。

方法 3:使用 Docker Rootless 模式

Docker 提供了 Rootless Mode(无特权模式),允许普通用户运行 Docker 容器,而无需 root 权限。

  1. 安装 Rootless Docker

    curl -fsSL https://get.docker.com/rootless | sh
    
  2. 设置环境变量

    安装完成后,执行以下命令来配置环境变量:

    export PATH=$HOME/bin:$PATH
    export DOCKER_HOST=unix://$XDG_RUNTIME_DIR/docker.sock
    

    让这些配置永久生效:

    echo 'export PATH=$HOME/bin:$PATH' >> ~/.bashrc
    echo 'export DOCKER_HOST=unix://$XDG_RUNTIME_DIR/docker.sock' >> ~/.bashrc
    source ~/.bashrc
    
  3. 启动 Rootless Docker

    systemctl --user start docker
    

Rootless 模式适用于不允许修改系统用户组的环境,比如某些企业级服务器。


总结

方法适用场景推荐级
添加用户到 docker适用于大多数情况,安全且便捷⭐⭐⭐⭐⭐(推荐)
使用 sudo 运行 Docker适用于临时使用,但不够方便⭐⭐⭐(不推荐)
Docker Rootless 模式适用于不能修改用户组的环境⭐⭐⭐⭐

最佳实践

如果你的服务器上有多个开发人员共用 Docker,建议使用 docker 组方式,这样既安全又方便。

你可以使用以下命令快速完成设置:

sudo groupadd docker
sudo usermod -aG docker $USER
newgrp docker
docker ps  # 测试是否生效

如果 docker ps 仍然报错,尝试 重新登录系统重启 Docker

sudo systemctl restart docker

这样,你的非 root 用户就可以 直接运行 Docker 并构建镜像 了!🚀

相关文章:

  • .CSV file input into contact of outlook with gibberish. .csv文件导入outlook, 出现乱码
  • 用户权限管控:三种免密切换方案对比
  • [mybatis]resultMap详解
  • SpringBoot 核心原理深度解析
  • Python学习第八天
  • 如何在Android中实现自定义视图
  • Vue 监听器的魔法之旅:@Watch(‘form.productId’) vs @Watch(‘value’) 大揭秘!✨
  • 大白话面试前的准备工作
  • Python +Anaconda,DeepSeeK API入门小例子
  • 智能决策新时代:大模型驱动的数据洞察与自动化报告生成
  • Spring Boot 常用注解全解析:从核心到进阶的实践指南
  • 10x Research:Secured Finance 基于 FIL 的美元稳定币如何推动 Filecoin 生态系统发展
  • elk的相关的基础
  • 真实项目中使用到的ES自定义评分脚本
  • GaussDB性能诊断核心武器:EXPLAIN ANALYZE 与执行计划
  • Git 使用教程
  • 敏捷开发之分支管理策略
  • Docker 学习(二)——基于Registry、Harbor搭建私有仓库
  • go数组的声明和初始化
  • Mysql命令大全(创建数据库显示数据库删除数据库)
  • 巴基斯坦军方:印度导弹袭击巴首都附近空军基地
  • AI药企英矽智能第三次递表港交所:去年亏损超1700万美元,收入多数来自对外授权
  • 夜读丨古代有没有近视眼?
  • 金融监管局:已设立74支私募股权投资基金,支持投资科技创新企业
  • 国家发改委:目前有的核电项目民间资本参股比例已经达到20%
  • 上海:下调个人住房公积金贷款利率