docker引擎是什么
Docker引擎是用来运行和管理容器的核心软件,其主要的组件构成有:Docker客户端(Docker Client)、Docker守护进程(Docker deamon)、containerd和runc。
本教程操作环境:linux5.9.8系统、docker-1.13.1版、Dell G3电脑。
1. Docker引擎简介
Docker引擎是用来运行和管理容器的核心软件
Docker 引擎由许多专用的工具协同工作,从而可以创建和运行容器,例如 API、执行驱动、运行时、shim 进程等。
- Docker引擎主要的组件构成:Docker客户端(Docker Client), Docker守护进程(Docker deamon),containerd以及runc。
2. Docker引擎详解
- Docker首次发布时,由两个核心组件构成:LXC和Docker daemon。
- Docker daemon是单一的二进制文件,包含诸如Docker客户端,Docker API,容器运行时,镜像构建等。
- LXC提供了对诸如命名空间和控制组(CGroup)等基础工具的操作能力,它们是基于Linux内核的容器虚拟化技术。在 Docker 0.9 版本中,Libcontainer 取代 LXC 成为默认的执行驱动。
2.1. Docker daemon
- Docker daemon整体性带来的越来越多的问题:
- 难于变更
- 运行越来越慢
- 这并非生态公司所期望的
- daemon使用一种CRUD风格的API,通过gRPC与containerd进行通信
2.2. runc
- runc实质上是一个轻量级的,针对Libcontainer进行了包装的命令行交互工具。
- runc作用:创建容器
2.3. containerd
- 主要作用:容器的生命周期管理–start|stop|pause|rm…
2.4. shim
- shim是实现无daemon的容器不可或缺的工具,runc每次创建新容器,都会fork一个新的runc实例,一旦容器创建完毕,对应的runc进程就会退出。
- 一旦父进程runc退出,相关联的container-shim进程就会成为容器的父进程
- shim的部分职责:
- 保持所有STDIN和STDOUT流是开启状态,从而当daemon重启的时候,容器不会因为管道的关闭而终止。
- 将容器的退出状态反馈给daemon。
2.5. 在Linux上的实现
- dockerd(Docker daemon), docker-containerd(containerd), docker-containerd-shim(shim)和docker-runc(runc)都是由单独的二进制实现。
2.6. daemon的作用
- 主要功能:镜像管理,镜像构建,REST API, 身份验证,安全,核心网络以及编排。
推荐学习:《docker视频教程》
以上是docker引擎是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文解释了Kubernetes的吊舱,部署和服务,详细说明了它们在管理容器化应用程序中的作用。它讨论了这些组件如何增强应用程序内的可扩展性,稳定性和通信。(159个字符)

本文使用手动缩放,HPA,VPA和集群Autoscaler讨论了Kubernetes中的扩展应用程序,并提供了监视和自动化缩放的最佳实践和工具。

本文讨论了Docker Swarm中实施滚动更新以更新服务而无需停机。它涵盖更新服务,设置更新参数,监视进度并确保更新。

Docker是DevOps工程师必备的技能。1.Docker是开源的容器化平台,通过将应用程序及其依赖打包到容器中,实现隔离和可移植性。2.Docker的工作原理包括命名空间、控制组和联合文件系统。3.基本用法包括创建、运行和管理容器。4.高级用法包括使用DockerCompose管理多容器应用。5.常见错误有容器无法启动、端口映射问题和数据持久化问题,调试技巧包括查看日志、进入容器和查看详细信息。6.性能优化和最佳实践包括镜像优化、资源限制、网络优化和使用Dockerfile的最佳实践。
