docker源码走读之debug 源码
查看docker源码过程中,如果不进行断点调试很难进行弄清调用的链路,所以本篇文章记录一下我走读docker源码的经验,发表的第一篇博客Mark一下,欢迎指正错误。
环境准备
docker源码编译需要在容器的环境中,docker官方将复杂的编译过程简单化提供了一个makefile和dockerfile。由于docker源码需要在容器中进行编译,so你需要安装好docker环境,make工具。你可以在主机上或者虚拟机中配置环境,本姑娘就是在virtualbox+vagrant环境中编译的。安装的步骤自行google or baidu很多资料这里不啰嗦了~
开始编译
从github上获取docker源码
git clone https://github.com/moby/moby.git
cd moby
这里我们可以看看docker官方提供的Dockerfile,安装go,golint等工具和环境:
make build自动build makefile中的配置镜像
DOCKER_IMAGE :=
docker-dev
(if
(GIT_BRANCH_CLEAN),:$(GIT_BRANCH_CLEAN)):
make binary过程使用make build过程中的cache:
在docker-dev run起的容器中编译源码:
可能会遇到内存不够问题更改Vagrantfile配置reload下可解决:
编译成功后可以在bundles路径中可看到二进制文件。
debug:
用debug模式启动docker daeemon :sudo dockerd -D
这里本妹纸遇到这种问题:
看了github上也有人遇到过,不过没有解答,于是删了/var/lib/docker目录果然奏效,原来多个docker daemon共享是不可以的,mark一下。
由于golang本身带有的异步特性,可以用打印日志的方式进行debug,当然也可以用gdb。
打印日志
打印日志的方式可以改源码输出变量内容,比如本妹纸在dispatchers.go的add func里加了如下:
在docker build时可以看到输出内容。
在daemon端我萌来看看client端的请求log:
client端返回结果打印输出。也可以用logrus打印daemon日志查看。
gdb
我用的源码是v17.06.0-dev版本,编译过程将二进制文件合并了。
合并在哪个文件里得找找了。比如builder目录下的文件编译之后在dockerd-17.06.0-dev里面
在dispatchers.go的add方法中打断点,这个得注意路径问题