本文分两部分,第一部分是手动计划任务的方式构建Github上的Docker程序,第二部分是用Github webhook Trigger一个自动构建任务。
Jenkins采用2.5版本
Docker采用1.7.1
代码托管使用的Github官网
系统为IBM Bluemix提供的Cent6.7,服务器地址在美国南加州
1.1 创建一个Freestyle Project, let's say jenkins-docker
1.2 Set workplace to /var/lib/jenkins/jobs/jenkins-docker/workplace
1.3 Add Github address:git@github.com:sangrealest/Jenkins_Docker_Ansible.git
Dockerfile 很简单,就是拉取最新的Nginx,并将2048游戏添加到Nginx根目录
1
2
3
4
5
6 1FROMnginx:latest
2MAINTAINERShankershanker@yeah.net
3ADD2048-master/usr/share/nginx/html
4ADDtestfile/root/
5EXPOSE80
6
1.4 Under Build Triggers, set Poll SCM: H * * * *
1.5 Under Build->Execute shell, use below shell script:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 1#!/bin/sh
2echo'>>>Getoldcontainerid'
3CID=$(dockerps|grep"jenkins-docker"|awk'{print$1}')
4echo$CID
5sudo/usr/bin/dockerbuild-tjenkins-docker/var/lib/jenkins/jobs/jenkins-docker/workspace|tee/var/lib/jenkins/jobs/jenkins-docker/workspace/Docker_build_result.log
6echo'>>>Stoppingoldcontainer'
7if["$CID"!=""];then
8sudo/usr/bin/dockerstop$CID
9fi
10echo'>>>Restartingdocker'
11sudoservicedockerrestart
12sleep5
13
14echo'>>>Startingnewcontainer'
15sudo/usr/bin/dockerrun-p3000:80-djenkins-docker
16
1.6 配置jenkins用户
因为jenkins service是用jenkins用户启动的,所有要执行docker相关命令需要将jenkins加入到docker group,赋予jenkins sudo without password
1
2
3
4 1sudousermod-Gdockerjenkins
2visudo,addbellow
3jenkinsALL=(ALL:ALL)NOPASSWD:ALL"
4
然后Build Project, 如果成打开运行Jenkins机器的3000端口会看到2048游戏的界面:
以上的构建是基于计划任务的,每小时的随机分钟内执行一次构建任务(SCM H * * * *),然后懒人还有懒人的做法,就是添加Github webhook功能,当push一个更新的时候自动trigger一次构建。
2.1 在Github个人主页上安装Github Plugin并添加你的Jenkins server的webhook地址:比如我的Jenkins地址是mywebsite.com:8080,这里要写的地址就应该是https://mywebsite.com:8080/github-webhook
2.2 返回jenkins-docker项目首页,点击 Configure, 添加Github的账号密码信息,因为我用的个人仓库,需要使用私钥认证,选择Certificate, 将放在jenkins home/.ssh 下的私钥路径填上:
2.3 Build Triggers 勾上Build when a change is pushed to Github
2.4 这时候可以更新一下Github Project下面的文件并且push一下,看看是否触发了jenkins的构建动作:
如图,我刚push完成,jenkins这边就已经捕捉到并且开始构建新的任务:
我们在Github项目地下echo 一句话到testfile,并且添加到容器的/root下时间是7:49:58,然后我的容器更新后并启动运行的时间是7:50:26,只用了28秒钟就构建成功了!
有了这样的集成,后续我们就可以考虑将Ansible也加进来,做持续部署,当把jenkins pipeline, docker, ansible都集成到一起,就是CI/CD完全集成工作了,或者用Mesos+Marathon+Docker云数据中心的方式来做持续部署。