一般来说,docker的进程是具有root权限的,但是在一些需要信息保密的业务场景中,存在着不能取得root权限的docker使用需求,对于这种需求,docker给出了rootless模式的方法,以下是非root的安装方法,官方文档链接:Rootless mode | Docker Docs

安装方法分为两类包管理工具安装和二进制安装

1.二进制安装

        防火墙放行443端口(这需要root权限,也是本文唯一一个需要root权限的操作)

 sudo ufw allow 443/tcp

        执行脚本

curl -fsSL https://get.docker.com/rootless | sh

         这里需要访问dockerhub,而且即使直接运行脚本,脚本中也有使用到dockerhub的部分,建议使用魔法

        执行完成后会输出一些命令,将这些命令中带有export前缀的添加到~/.bashrc文件的最下面,例如:

export PATH=/home/你自己的名字/bin:$PATH
export DOCKER_HOST=unix:///run/user/1000/docker.sock

         而常用的配置文件如下:

docker.service     路径: ~/.config/systemd/user/docker.service

docker.sock         路径:$XDG_RUNTIME_DIR/docker.sock(这个环境变量一开始的输出会有)

daemon.json       路径:~/.config/docker/daemon.json(这个文件可能需要自己创建)

config.json          路径:~/.docker

        添加环境变量,否则告警:

export DOCKER_HOST=unix://$XDG_RUNTIME_DIR/docker.sock

         将docker作为rootless方式运行

docker context use rootless

        测试容器:

docker run -d -p 8080:80 nginx

        最后修改daemon.json文件中的registry,值得注意的是,修改完daemon.json后,重启docker需要指定--user参数,如:

systemctl --user daemon-reload
systemctl --user restart docker
systemctl --user enable docker

至此docker rootless初步配置完成,出现意料之外的bug移步troubleshooting章节Rootless mode | Docker Docs

2.包管理器安装

        安装必须包

apt-get install -y docker-ce-rootless-extras

        如果有必要可以更新包

        安装完成后在/usr/bin中可以找到文件dockerd-rootless-setuptool.sh,执行它

dockerd-rootless-setuptool.sh install

接下来回到刚刚的export接着执行就好了

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐