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
相关推荐
石像鬼₧魂石3 小时前
Kali Linux 中对某(靶机)监控设备进行漏洞验证的完整流程(卧室监控学习)
linux·运维·学习
Hqst_xiangxuajun3 小时前
服务器主板选用网络变压器及参数配置HX82409S
运维·服务器·网络
CS创新实验室3 小时前
练习项目:基于 LangGraph 和 MCP 服务器的本地语音助手
运维·服务器·ai·aigc·tts·mcp
私人珍藏库3 小时前
Microsoft 远程桌面app,支持挂机宝,云主机服务器
运维·服务器·microsoft
“愿你如星辰如月”3 小时前
Linux:进程间通信
linux·运维·服务器·c++·操作系统
10岁的博客4 小时前
二维差分算法高效解靶场问题
java·服务器·算法
Code Warrior5 小时前
【Linux】应用层协议HTTP
linux·网络·网络协议·http
Hello,C++!6 小时前
linux下libcurl的https简单例子
linux·数据库·https
踏雪Vernon6 小时前
[OpenHarmony6.0][Docker][环境]OHOS6 编译环境构建指南
运维·docker·容器