文章标题

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方法中打断点,这个得注意路径问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值