Linux 服务器配置 rootless docker Quick Start

流程

  • Root 用户安装 Rootless Docker 必需包
  • 普通用户可独立初始化自己的 Rootless Docker 环境
  • 普通用户无需 sudo 即可使用 Docker

Root 用户操作:安装 Rootless Docker 支持包

可参考 Docker官方文档 下载 Docker必须的配置。如果出现防火墙错误curl: (35) OpenSSL SSL_connect: Connection reset by peer in connection to download.docker.com:443,可以用国内镜像源

bash 复制代码
# 1. 更新 apt 包索引
sudo apt-get update
sudo apt install ca-certificates curl gnupg lsb-release uidmap

sudo install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /etc/apt/keyrings/docker.gpg
sudo tee /etc/apt/sources.list.d/docker.sources <<EOF
Types: deb
URIs: https://mirrors.aliyun.com/docker-ce/linux/ubuntu
Suites: $(. /etc/os-release && echo "${UBUNTU_CODENAME:-$VERSION_CODENAME}")
Components: stable
Signed-By: /etc/apt/keyrings/docker.gpg
EOF
Types: deb
URIs: https://mirrors.aliyun.com/docker-ce/linux/ubuntu
Suites: jammy
Components: stable
Signed-By: /etc/apt/keyrings/docker.gpg

sudo apt-get update

# 下载 docker-ce-rootless-extras
sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-ce-rootless-extras

注意:这是全局安装包,只安装可执行文件和 Rootless 支持工具,不会自动启动 daemon。


普通用户初始化 Rootless Docker

普通用户在登录 shell 后执行:

bash 复制代码
# 1. 设置必要环境变量
export XDG_RUNTIME_DIR=$HOME/.docker/run
export PATH=/usr/bin:$PATH
export DOCKER_HOST=unix://$XDG_RUNTIME_DIR/docker.sock

# 2. 创建运行目录
mkdir -p "$XDG_RUNTIME_DIR"

# 3. 初始化 Rootless Docker daemon
dockerd-rootless-setuptool.sh install
# 会在用户目录创建 Rootless Docker 数据目录和配置

解释

  • XDG_RUNTIME_DIR → 存放 socket 和状态文件
  • PATH → 确保能找到 docker 命令
  • DOCKER_HOST → 告诉 CLI 去哪个 socket 通信
  • dockerd-rootless-setuptool.sh install → 初始化用户自己的 Rootless Docker 环境

启动 Rootless Docker(每次登录或手动)

bash 复制代码
# 临时前台启动
dockerd-rootless.sh
# 前台运行,终端关闭后 daemon 停止

# 后台启动并写日志
dockerd-rootless.sh > ~/.docker/rootless.log 2>&1 &

自动启动(推荐)

~/.bashrc~/.zshrc 添加:

bash 复制代码
export XDG_RUNTIME_DIR=$HOME/.docker/run
export PATH=/usr/bin:$PATH
export DOCKER_HOST=unix://$XDG_RUNTIME_DIR/docker.sock

mkdir -p "$XDG_RUNTIME_DIR"

# 自动启动 Rootless Docker(如果未运行)
if ! pgrep -u "$USER" dockerd-rootless.sh > /dev/null; then
    dockerd-rootless.sh >> ~/.docker/rootless.log 2>&1 &
fi
  • 每次登录 shell 自动启动 Rootless Docker
  • 日志保存到 ~/.docker/rootless.log
  • 避免重复启动导致 lock 错误

然后运行

bash 复制代码
source ~/.bashrc
dockerd-rootless-setuptool.sh install

测试 Docker 是否可用

Docker Rootless官方文档

bash 复制代码
docker info

注意事项

  1. 端口限制:Rootless Docker 只能绑定 >1024 端口
  2. 性能 :网络通过 slirp4netns,比 root Docker 略慢
  3. 数据隔离:每个用户自己的镜像和容器互不影响
  4. 停止/启动:关闭终端或 logout 后,非自动启动 daemon 会停止

✅ 总结流程

步骤 Root/普通用户 指令 作用
1 root sudo apt-get install -y docker-ce-rootless-extras uidmap 安装 Rootless Docker 支持包
2 普通用户 export XDG_RUNTIME_DIR=...; mkdir -p $XDG_RUNTIME_DIR; dockerd-rootless-setuptool.sh install 初始化 Rootless Docker 环境
3 普通用户 dockerd-rootless.sh 或后台启动 启动用户 daemon
4 普通用户 .bashrc 自动启动 登录自动启动 Rootless Docker
5 普通用户 docker info 测试 Docker 是否连接到Rootless daemon
相关推荐
qq_455760853 小时前
docker - 镜像、存储卷和网络深入理解
运维·docker·容器
2501_945837434 小时前
云服务器的技术本质与发展演进
服务器
秋4274 小时前
防火墙基本介绍与使用
linux·网络协议·安全·网络安全·架构·系统安全
取加若则_4 小时前
深入解析Linux进程优先级机制
linux·服务器
点亮一颗LED(从入门到放弃)4 小时前
设备模型(10)
linux·服务器·前端
Web极客码4 小时前
使用VPS主机进行数据分析的主要优势
linux·windows·vps主机
一只废狗狗狗狗狗狗狗狗狗5 小时前
基于docker desktop的hadoop集群结点启动失败问题
hadoop·docker·docker desktop
九思x5 小时前
Linux 系统安装 JDK 17
linux·运维
HIT_Weston5 小时前
77、【Ubuntu】【Hugo】搭建私人博客:Detached HEAD
linux·运维·ubuntu
再睡一夏就好6 小时前
多线程并发编程核心:互斥与同步的深度解析及生产者消费者模型两种实现
linux·运维·服务器·jvm·c++·笔记