当前位置: 代码网 > 服务器>服务器>云虚拟主机 > 让非root用户构建Docker镜像的三种方法

让非root用户构建Docker镜像的三种方法

2025年04月24日 云虚拟主机 我要评论
前言在默认情况下,docker 需要root权限或sudo才能运行。这对于日常开发和 ci/cd 流水线可能不够方便,也可能带来安全隐患。那么,如何让非 root 用户也能构建和运行 docker容器

前言

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

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

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

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

  • 创建 docker 组(如果不存在)
sudo groupadd docker
  • 将用户加入 docker 组
sudo usermod -ag docker $user
  • 如果你要添加其他用户,替换 $user 为具体的用户名:
sudo usermod -ag docker your-username
  • 重新登录使权限生效

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

newgrp docker
  • 测试是否生效
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 权限。

  • 安装 rootless docker
curl -fssl https://get.docker.com/rootless | sh
  • 设置环境变量

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

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
  • 启动 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 并构建镜像 了!

到此这篇关于让非root用户构建docker镜像的三种方法的文章就介绍到这了,更多相关非root用户构建docker镜像内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com