openEuler 22.03 LTS Rootless Docker 安装指南

openEuler 22.03 LTS Rootless Docker 安装指南

1.创建普通用户(用于无根模式)

bash 复制代码
sudo useradd -m docker-user
sudo passwd docker-user  # 设置密码
sudo usermod --add-subuids 100000-165535 docker-user
sudo usermod --add-subgids 100000-165535 docker-user

2. 切换到普通用户,直接安装 Rootless Docker

ini 复制代码
# 切换到新用户
sudo -u docker-user -i
# 下载安装脚本(如果失败,多执行几次)
curl -fsSL https://get.docker.com/rootless -o get-docker.sh
# 安装(跳过rootful Docker检查)
sh get-docker.sh --skip-install-rootless
# 安装 Rootless Docker(可不需要,但是可以查看下面的环境变量)
dockerd-rootless-setuptool.sh install
# 设置环境变量
echo 'export XDG_RUNTIME_DIR=/home/yujiaqi/.docker/run' >> ~/.bashrc
echo 'export PATH=/home/yujiaqi/bin:$PATH' >> ~/.bashrc
echo 'export DOCKER_HOST=unix:///home/yujiaqi/.docker/run/docker.sock' >> ~/.bashrc
source ~/.bashrc

3. 配置镜像源

bash 复制代码
mkdir -p ~/.config/docker
cat > ~/.config/docker/daemon.json << EOF
{
  "registry-mirrors": [
  	"https://docker.m.daocloud.io",
  	"https://dockerproxy.com",
  	"https://docker.mirrors.ustc.edu.cn",
  	"https://docker.nju.edu.cn",
  	"https://dockerhub.icu",
  	"https://docker.registry.cyou",
  	"https://docker-cf.registry.cyou",
  	"https://dockercf.jsdelivr.fyi",
  	"https://docker.jsdelivr.fyi",
  	"https://dockertest.jsdelivr.fyi",
  	"https://mirror.aliyuncs.com",
  	"https://dockerproxy.com",
  	"https://mirror.baidubce.com",
  	"https://docker.m.daocloud.io",
  	"https://docker.nju.edu.cn",
  	"https://docker.mirrors.sjtug.sjtu.edu.cn",
  	"https://docker.mirrors.ustc.edu.cn",
  	"https://mirror.iscas.ac.cn",
  	"https://docker.rainbond.cc"
  ],
  # 修改存储位置(如需要),默认是~/.local/share/docker
  "data-root": "/var/lib/docker-rootless"
}
EOF

4. 手动启动 Docker 守护进程

bash 复制代码
# 启动守护进程(后台运行)
nohup dockerd-rootless.sh > ~/docker.log 2>&1 &
# 检查是否运行
ps aux | grep dockerd

5. 验证 Docker 连接

bash 复制代码
# 等待 5-10 秒让守护进程启动
sleep 10
# 测试 Docker 命令
docker ps
docker run --rm hello-world

6. 迁移现有镜像(可选)

如果是后续才更改的存储位置,可以使用下面方法迁移镜像

bash 复制代码
# 创建用户目录
sudo mkdir -p /var/lib/docker-rootless/zengshun
# 设置所有权和权限(关键步骤)
sudo chown zengshun:zengshun /var/lib/docker-rootless/zengshun
sudo chmod 700 /var/lib/docker-rootless/zengshun  # 仅用户自己可访问
# 1. 停止 Docker
pkill -f dockerd-rootless
# 2. 迁移数据(保留权限)
rsync -av ~/.local/share/docker/ /var/lib/docker-rootless/zengshun/
# 3. 删除旧数据(确认迁移成功后)
rm -rf ~/.local/share/docker
相关推荐
梦梦代码精6 小时前
电商系统不是技术堆叠:LikeShop如何用分层Hold住复杂业务?
java·docker·代码规范
Tian_Hang7 小时前
Eclipse Ditto 物模型相关代码
java·运维·服务器·ide·eureka·eclipse
zhoupenghui1688 小时前
【AI大模型应用开发】【项目实战】13.RAG智慧问答项目-(一)项目介绍&项目架构&项目环境配置
人工智能·docker·ai·milvus·rag·attu·rag智慧问答项目
江畔柳前堤10 小时前
第13章:docker生产环境部署实战
运维·git·docker·容器·代码复审
hj28625113 小时前
Docker 容器化技术标准化笔记
java·笔记·docker
潘正翔13 小时前
docker基础_镜像使用
linux·运维·服务器·docker·容器·centos·devops
江湖有缘13 小时前
Lunalytics部署指南:使用Docker快速搭建私有监控面板
运维·docker·容器
分布式存储与RustFS14 小时前
RustFS保姆级教程:Docker快速部署兼容S3的本地对象存储
运维·docker·容器·rustfs部署教程·本地搭建s3对象存储·rustfs网页控制台使用·awscli连接rustfs
江湖有缘14 小时前
Docker部署Papra极简文件归档平台
运维·docker·容器
qq_3494479515 小时前
十四、k8s集群安装kube-state-metrics 组件
docker·容器·kubernetes