网站首页 > 技术文章 正文
Docker 引擎
三层,
最下面的是一个一直运行的后台进程 dockerd
REST API提供了外界同dockerd交互的途径
最上面的docker CLI就是使用了RESTAPI
其他很多docker应用使用了CLI和RESTAPI
Docker架构属于CS模式,有daemon作为server,处理请求。客户端client可以在同一台机器上,也可以远程调用daemon的服务。
daemon负责管理镜像、容器、网络、挂载等资源,也可以同其他deamon交互,共同管理service
看第二张图上,又出来一个新的概念 Registry
这是存放镜像的地方。默认的公共镜像仓库就是https://hub.docker.com/
我们也可以搭建自己的镜像仓库,一般公司里都是这么干的
在执行docker pull 或者 docker run时,会从镜像仓库拉取镜像
执行docker push时,把自己打好的镜像,推送到仓库
一些概念:
IMAGES:镜像。只读的,构建容器的模板。一般我们构建镜像,都是基于一个更基础的镜像。在基础镜像之上,再加上自己的一些设置。就成了自己的镜像。这些是通过编写Dockerfile文件来做的。镜像是一层层叠加起来的。你在dockerfile里没写一个指令,就是在基础镜像上加一层。很像盖房子。当你修改了一些配置,重新构建镜像时,只有你修改的部分会重新构建,这是docker能做到轻量化的原因之一。
container :容器。一个镜像的运行实例。除了可以进行创建、运行、停止、删除、移动等基础操作之外,还可以基于当前容器的状态打出一个镜像。每个容器的运行环境和其他容器都是隔离的。也可以手工配置网络、存储等的隔离级别。容器的network是会利用主机的网络的。
Services :服务。对服务的消费者来看,一个Service就是一个单独的应用。但实际上,一个服务可以有多个容器节点支撑,通过负载均衡来抗很大的压力。通过服务编排,我们可以配置比如说要有多少个实例,这样一旦有容器节点宕机,服务编排会自动拉起新的容器,来达到我们设定的数量。
底层技术:
docker利用了很多linux的内核特性。
Namespaces:docker能做到容器间隔离,利用了namaspace技术。当拉起一个容器时,docker会为这个容器创建一组namespaces。通过namespace来保障容器的隔离性,有以下namespace:
pid namesapce:进程间隔离
net namespace:基于网络栈的隔离,每个容器有自己的网络
ipc namespace: 进程间通信
mnt namespace:基于文件挂载点的隔离
uts namespace:基于内核版本隔离
control groups,也称cgroups
cgroups技术是docker引擎用来限制容器可以使用的资源
本质上对CGroup的所有操作都是对系统挂载的CGroup目录进行修改,在/sys/fs/cgroup/<controller>目录下创建新的目录
Union file systems 联合文件系统
docker在构建镜像时,用到这个技术。前面说过,镜像是一层层叠加的,正是利用了ufs。
container format 容器的格式
docker引擎将上面这三种底层技术组合起来称为一个container format。默认的container format是libcontainer
猜你喜欢
- 2024-10-14 Docker Overlay 网络学习 dockercompose 网络
- 2024-10-14 盘点c++几种常见的设计模式及具体实现
- 2024-10-14 Docker新手福音!这个开源控制面板让你更快上手Docker
- 2024-10-14 Docker-掌握这三种方法,创建自己的docker镜像
- 2024-10-14 docker 基础概念 docker基于什么
- 2024-10-14 小白也能轻松上手,深度体验绿联私有云DX4600 Docker功能
- 2024-10-14 一文带你了解docker常用命令 docker常用命令及参数
- 2024-10-14 Docker最佳实践的反模式 docker反向代理
- 2024-10-14 docker中容器如何实现通信 docker容器之间如何通信
- 2024-10-14 工程化Docker:确保应用程序的可靠性、可扩展性和可维护性
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)