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

ops/2025/3/9 20:32:31/

如何让非 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 并构建镜像 了!🚀


http://www.ppmy.cn/ops/164483.html

相关文章

IntersectionObserver接口介绍

IntersectionObserver API 是浏览器提供的一个用于异步观察目标元素与其祖先元素或视口(Viewport)交叉状态(即是否进入或离开视口)的接口。在 IntersectionObserver 出现之前,开发者通常需要通过监听 scroll 事件或使用…

企业网站整站源码 开源企业网站源码模板

企业网站已成为企业对外展示形象、推广产品和服务的重要窗口。然而,对于许多中小企业来说,开发一个功能完善、设计精美的企业网站往往面临着高昂的成本和复杂的技术挑战。开源企业网站源码模板的出现,为企业解决这一难题提供了高效、经济的解…

【DeepSeek】Ubuntu快速部署DeepSeek(Ollama方式)

文章目录 人人都该学习的DeepSeekDeepSeek不同版本功能差异DeepSeek与硬件直接的关系DeepSeek系统兼容性部署方式选择部署步骤(Ollama方式)1.选定适合的deepseek版本2.环境准备3.安装Ollama4.部署deepseek5.测试使用 人人都该学习的DeepSeek DeepSeek 作…

UE5 蓝图项目转换为 C++项目

步骤 1:确认项目类型 蓝图项目:仅支持蓝图脚本,"File" 菜单中不会有 C 相关选项。C 项目:支持 C 代码,允许创建和使用 C 类。 图像描述表明当前项目是蓝图项目,因此需要将其转换为 C 项目。 步…

MySQL中的脏读与幻读:概念、影响与解决方案

在数据库事务处理中,脏读和幻读是两种常见的并发问题,可能导致数据不一致或逻辑错误。本文将结合实际场景,深入解析两者的原理及解决方案。 一、脏读(Dirty Read) 1. 概念解析 脏读指一个事务读取了另一个事务未提交…

RabbitMQ 高级特性解析:RabbitMQ 消息可靠性保障 (上)

RabbitMQ 核心功能 RabbitMQ 高级特性解析:RabbitMQ 消息可靠性保障 (上)-CSDN博客 RabbitMQ 高级特性:从 TTL 到消息分发的全面解析 (下)-CSDN博客 前言 最近再看 RabbitMQ,看了看自己之前写…

CCF-GESP Python一级考试全解析:网络协议+编程技能双突破

第一章 CCF-GESP考试全景透视 1.1 认证体系权威性 中国计算机学会(CCF)主办的GESP编程能力等级认证,是国内首个面向青少年的编程能力标准化评估体系。Python一级考试作为入门级认证,主要考察考生对计算机基础逻辑、编程工具使用及…

cmake使用笔记

cmake简单示例 以下是一个分目录的简单 CMakeLists.txt 示例,展示如何组织一个多目录项目,并使用 CMake 构建。 项目目录结构 MyProject/ ├── src/ # 源文件目录 │ ├── main.cpp # 主程序入口 │ ├── utils.cpp …