概述
Docker in Docker(DinD)是一个让 Docker 容器内可以运行另一个 Docker 沙箱环境的技术。常用于持续集成(CI)工作流程,其中需要构建和推送 Docker 镜像,而不污染主宿主机的 Docker 环境。
Docker in Docker 的工作原理
Docker 容器通常用于隔离应用程序和其运行环境。当你在 Docker 容器内部运行另一个 Docker 实例(称为 Docker in Docker)时,实际上是在原有的 Docker 容器中启动了一个新的 Docker 守护进程。这个新的 Docker 守护进程拥有自己的环境,包括镜像、容器和网络配置等,与宿主机的 Docker 环境隔离。
基本的Docker in Docker原理可以通过以下几个步骤概括:
-
Docker守护进程:
- 在宿主机上运行的Docker守护进程(dockerd)管理着所有的Docker对象,比如镜像、容器、网络和卷。
-
启动Docker-in-Docker容器:
- 使用具备特权(
--privileged
)的Docker容器来运行另一个Docker守护进程。因为Docker容器通常有一套严格的安全限制,所以这个--privileged
标志会给容器提供完全的主机设备访问权限。
- 使用具备特权(
-
Docker套接字:
- Docker客户端通常通过Unix socket与Docker守护进程进行通信。在Do