docker源码分析(5)---daemon

说明:此文章为腾讯云机器自动从本人csdn博客搬迁过来。是本人授权操作。

申明:无本人授权,不可转载本文。如有转载,本人保留追究其法律责任的权利。

龚浩华,QQ 29185807,月牙寂 道长

第一时间获取文章,可以关注本人公众号 月牙寂道长 yueyajidaozhang

daemon是docker中最主要的部分,其中封装了所有的东西。

下面我们直接看代码吧

1、初始化流程

main函数

docker\docker\docker.go

main函数中进入mainDaemon

在mainDaemon中,初始化 NewDaemon

代码在docker\daemon\daemon.go

其实是调用了NewDaemonFromDirectory

网络部分参数的检查

我们继续

再继续

我们看到了graphdriver的初始化

还有很多的driver的初始化

tagStore的初始化,networkdriver的初始化

graphdb的初始化

execdriver的初始化,然后是Daemon结构体初始化

整个初始化,很长,但所有的准备工作都初始化好了。

2、Install

向Engine中注册处理handler

这里注册了很多的处理命令,在注册完之后,也还调用了repositores的注册,和trustStore的注册。

看到上面所注册的命令,我们应该很熟悉了(如果对docker命令有用过的话)

3、Handler

下面就简单讲解下注册的handler

3.1、Create

Create命令,相对应的注册为ContainerCreate

我们进入跟踪看看

代码在docker\daemon\create.go

获取参数,然后对参数进行检查

参数准备好后,进入了Create函数

我们来看看Create函数

先查找image

接着参数检查,创建了一个新的Container,然后将其注册放到一个存储里。一会会介绍

然后就是一些其他的操作。

3.1.1、 newContainer

我们看看newContainer

3.1.2、 register

这里要讲下Daemon结构体有一个成员

contStore

代码在docker\daemon\daemon.go

代码很简单,就是一个带锁的map

现在进入register

首先是防止重入,判断是否已经存在。

然后依旧还是一些参数的初始化,继续

这里面将其添加到containers中

这里的操作是Create,如果Container正在运行的话,将其kill掉

3.2、execCreate

execCreate对应的handler是ContainerExecCreate

代码在docker\daemon\exec.go

先从getActiveContainer获取到Container,然后从获取config等

然后构建了execConfig,调用registerExecCommand进行注册

3.2.1 getActiveContainer

这里是获取Container

并判断是否是存活的

这里的get就是从Containers(一个带锁的map)中获取到的

3.2.2 registerExecCommand

在讲解着 之前,我们看看Daemon结构体中有一个成员execStore

execStore也是一个带锁的map

从这里来看在Container结构体中冶有一个execStore的map

3.3 execStart

execStart 对应的handler是ContainerExecStart

先获取execconfig

上面有一个Attach,就是一个输入输出的attach。

最关键的地方在这里,调用了Container.Exec

3.3.1 getExecConfig

这里就是从execStore中查找到对应的execConfig

3.3.2 Container. Exec

最终进入的是Container.Exec

我们看看这个函数

构造了一个callback

调用了monitorExec

继续跟踪

这里又重新回到了Daemon.Exec

3.3.3、Daemon.Exec

最终的执行还是进入到了Daemon.Exec

从代码中看出,最后进入了execDriver.Exec

3.3.4 小结

这里讲解了部分的handler,但基本流程都已经清晰了。其他的handler就不再做详细讲解

4、总结

Daemon是整个框架的管理员,管理着几乎所有的模块。并向Engine注册了很多的command handler,是整个的核心部分。

文中如果有哪里讲解的不对的地方,还请见谅,望指正

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐百川的学习频道

Python 日志输出

打印日志是很多程序的重要需求,良好的日志输出可以帮我们更方便的检测程序运行状态。Python标准库提供了logging模块,让我们也可以方便的在Python中打...

3659
来自专栏happyJared

Jmeter 压测 http(s)

  上一篇文章关于Jmeter介绍了Jmeter入门相关的知识。本文是实战篇,讲讲如何使用Jmeter对Http(s)进行压力测试。

6122
来自专栏技术问题

中小型局域网本地配置路由器的详细方法?

中小型企业配置路由器的方法和其他路由器配置很相似,这里我们主要讲解了中小型局域网本地配置路由器的详细方法,接着双击刚刚创建好的“PerformRouterDis...

1290
来自专栏用户2442861的专栏

tinyhttpd 剖析

http://blog.csdn.net/jcjc918/article/details/42129311

2172
来自专栏闵开慧

tomcat6.0下找不到jasper-runtime.jar

今天有点需求,需要用jasper-runtime.jar包。但是我在我的\apache-tomcat-6.0.16\lib目录下,怎么也找不到这个jar包。结果...

3405
来自专栏流柯技术学院

Ant_build.xml的最完整解释

Ant的概念 Make命令是一个项目管理工具,而Ant所实现功能与此类似。像make,gnumake和nmake这些编译工具都有一定的缺陷,但是Ant却克服了这...

1362
来自专栏静默虚空的博客

spring 4 升级踩雷指南

spring 4 升级踩雷指南 前言 最近,一直在为公司老项目做核心库升级工作。本来只是想升级一下 JDK8 ,却因为兼容性问题而不得不升级一些其他的库,而其他...

3899
来自专栏编程软文

快速上手友盟推送前后端

3215
来自专栏Python

flask celery 使用方法

由于celery4.0不支持window,如果在window上安装celery4.0将会出现下面的错误

4420
来自专栏企鹅号快讯

Python模块知识5:日志logging

logging模块提供了通用的日志系统,可以采用不同的方式记录日志,比如文件,HTTP、GET/POST,SMTP,Socket等,甚至可以自己实现具体的日志记...

2227

扫码关注云+社区

领取腾讯云代金券