DooD:Docker+Jenkins

第一次发布博客。希望可以给需要的朋友们一些帮助。

1. 基础环境

本文基于64位的CentOS 7.2系统,内核版本如下:

图1 宿主机的操作系统内核版本

Docker版本如下:

图2 Docker版本

如需安装Docker,请点击:安装Docker

如需安装Docker加速器,请点击:配置Docker加速器

2.在容器中调用docker命令有以下几种方式

2.1 DooD(Docker-outside-of-Docker)

其实就是运行一个Jenkins镜像的docker容器,这种方式使用socket套接字(一般默认是/var/run/docker.sock文件)和宿主机进行交互,只限于本地通信。不会去监听任何端口。在创建Jenkins镜像时,可以给jenkins用户赋予sudo权限来调用docker命令;或者将jenkins用户加入到docker组,就可以直接在容器中调用docker命令,下文会分别讲到两种情况的Dockerfile的写法。不过相比较于不同的宿主机docker组的不同,使用sudo更具有普适性和可移植性。

2.2 DinD(Docker in Docker)

顾名思义,就是在Docker容器中重新安装一个Docker应用。容器中安装Docker和宿主机安装的Docker是完全没有关联的两个程序。一般情况下,我们想要的只是一个运行于docker的CI/CD环境,我们需要容器内外只有一个docker engine。 DinD显然比我们想要的要复杂的多,而且可能还有一些意想不到的问题会出现。

更详细的了解,请参考下面两篇文章:

https://zhuanlan.zhihu.com/p/27208085

https://github.com/jpetazzo/dind

2.3 使用HTTP/HTTPS与Docker Engine通讯

Docker还可以对外暴露Remote API,通过http/https就可以与docker engine进行通信,因为打开Remote API相应的要对外暴露端口,所以相对来说是不安全的。

在Jenkins容器中可以通过配置相应的Docker plugin,并在“系统管理”——>“系统设置”——>“云”中增添响应的Remote API信息。

详细信息请参考:

https://docs.docker.com/engine/security/https/

进过对比,我使用的是第一种方式:DooD。

注意点:请确保宿主机的doeker server已经开启本地套接字访问和远程通信

3.在宿主机上开启本地套接字访问和远程通信

默认情况下,Docker守护进程会生成一个socket(/var/run/docker.sock)文件来进行本地进程通信,而不会监听任何端口,因此只能在本地使用docker客户端或者使用Docker API进行操作。

如果想在其他主机上操作Docker主机,就需要让Docker守护进程监听一个端口,这样才能实现远程通信。

目前开启本地套接字访问和远程通信有以下两种方式:

3.1 修改/etc/docker/daemon.json

把以下内容添加进json文件中,注意添加前请确认2375端口是否被占用!!!

如下图所示:

图3 开启Docker socket套接字和Remote API

sudo vi /etc/docker/daemon.json

{

"hosts": ["unix:///var/run/docker.sock","tcp://0.0.0.0:2375"]

}

sudo systemctl daemon-reload

sudo service docker restart

3.2 修改/etc/systemd/system/docker.service

sudo vi /etc/systemd/system/docker.service

ExecStart=/usr/bin/dockerd –H tcp://0.0.0.0:2375 -Hunix:///var/run/docker.sock

sudo systemctl daemon-reload

sudo service docker restart

以上两种方式都可以通过下面的方式验证 docker remote API的2375端口是否开启

netstat -apn | grep 2375

4. 搭建jenkins(DooD模式)

4.1 新建挂载目录

在本地宿主机上新建一个Jenkins镜像数据的挂载目录,进行Jenkins数据的备份和持久化;因为Jenkins镜像中的Dockerfile中/var/jenkins_home权限为1000:1000,所以此处我们需要修改宿主机上的挂载目录权限,否则会出现权限不足的问题。注意:如果在生产中这样使用,一开始需要给/var/jenkins分配一个合理的容量,否则随着jenkins构建的增多会出现空间不足等问题。如下图:

图4 创建Jenkins挂载目录
图5  Dockerfile中的JENKINS_HOME

sudo mkdir /var/jenkins

sudo chown 1000:1000 /var/jenkins/

ls -al /var/jenkins/

4.2 编写Dockerfile

第一种:在docker容器中,jenkins用户使用sudo执行docker命令

FROM jenkins/jenkins:lts

MAINTAINER Allen

USER root

#清除了基础镜像设置的源,切换成阿里云的jessie加快构建镜像速度

RUN echo '' > /etc/apt/sources.list.d/jessie-backports.list \

       && echo "deb http://mirrors.aliyun.com/debian jessie main contrib non-free" > /etc/apt/sources.list \

       && echo "deb http://mirrors.aliyun.com/debian jessie-updates main contrib non-free" >> /etc/apt/sources.list \

       && echo "deb http://mirrors.aliyun.com/debian-security jessie/updates main contrib non-free" >> /etc/apt/sources.list

RUN apt-get update -y \

      && apt-get install -y sudo \

      && apt-get install -y libltdl7 \

      && rm -rf /var/lib/apt/lists/*

RUN echo "jenkins ALL=NOPASSWD: ALL" >> /etc/sudoers

USER jenkins

第二种:在docker容器中,jenkins用户可直接使用docker命令

FROM jenkins/jenkins:lts

MAINTAINER Allen

USER root

ARG docker_gid=1001

#清除了基础镜像设置的源,切换成阿里云的jessie加快构建镜像速度

RUN echo '' > /etc/apt/sources.list.d/jessie-backports.list \

    && echo "deb http://mirrors.aliyun.com/debian jessie main contrib non-free" > /etc/apt/sources.list \

    && echo "deb http://mirrors.aliyun.com/debian jessie-updates main contrib non-free" >> /etc/apt/sources.list \

    && echo "deb http://mirrors.aliyun.com/debian-security jessie/updates main contrib non-free" >> /etc/apt/sources.list

RUN apt-get update -y \

     && apt-get install -y libltdl7 \

    && rm -rf /var/lib/apt/lists/*

RUN echo "docker:x:${docker_gid}:jenkins" >> /etc/group

USER jenkins

我选用的是第二种,但是因为所在宿主机的不同,docker_gid会有所差异,建议使用第一种方式。

4.3 构建jenkins镜像

在上一步构建好的Dockerfile所在目录,执行下面的命令构建Jenkins镜像

docker build -t jenkins:v1 .


图6 构建成功部分日志

4.4 启动Jenkins容器

使用上一步构建好的镜像,启动Jenkins容器,命令如下

docker run -d -p 8080:8080 -p50000:50000 --name jenkins -v /var/jenkins/:/var/jenkins_home -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/usr/bin/docker jenkins:v1

图7 启动Jenkins容器

4.4 查看Jenkins日志

使用如下命令查看安装密码,也可直接去看容器里边对应位置的文件(/var/jenkins_home/secrets/initialAdminPassword),或者去宿主机挂载的目录下查看文件(/var/jenkins//secrets/initialAdminPassword)

docker logs jenkins

图8 查看Jenkins安装密码

4.5 按步骤安装Jenkins

图9 Jenkins安装步骤1
图10 Jenkins安装步骤2
图11 Jenkins安装步骤3
图12 Jenkins安装步骤4  
图13 Jenkins安装步骤5 

5. 搭建过程遇到的问题(未完待续)

5.1 docker-client版本问题

Q1:搭建的jenkins容器出现下列错误,在容器中无法正常运行docker命令,可能是docker client的版本问题。

图14 Jenkins-client版本问题

我当时出现问题的版本如下:

图15 docker version

A1:该问题,有两种解决办法:第一,卸载重新安装合适的版本,上图这个版本是我使用yum install 安装的版本;第二种,只需安装docker-client。

参考资料:

Docker官网:https://www.docker.com/

Docker社区:https://forums.docker.com/

DaoCloud:https://www.daocloud.io/

DockOne:http://dockone.io/

Jenkins Base Dockerfile Github:https://github.com/jenkinsci/docker/blob/master/Dockerfile

https://zhuanlan.zhihu.com/p/27208085

https://www.cnblogs.com/leolztang/p/6934694.html

https://blog.csdn.net/xinluke/article/details/52267995

https://www.cnblogs.com/leolztang/p/6934694.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,240评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,328评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,182评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,121评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,135评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,093评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,013评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,854评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,295评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,513评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,398评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,989评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,636评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,657评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容