文档章节

基于Jenkins+Docker的自动化代码发布流程

opsonly
 opsonly
发布于 03/28 13:57
字数 1257
阅读 25
收藏 12

前段时间写了一篇初创团队持续集成的落地与实现,主要用python接收gitlab的push请求,然后调用不同的shell脚本来实现。本文将使用基于Jenkins+Docker来实现另一套的自动化CI/CD的代码发布流程,至于jenkins和docker是什么这里就不多说了,能找到这篇文章的应该都知道他们是干什么用的,下面是整体的流程和部署。

一、总体流程设计

流程解析:

1、开发人员将代码推送至git仓库。

2、通过Jenkins上事先设置好的触发器来拉取git仓库的代码。

3、代码在Jenkins上通过设置好的规则编译打包,然后build成docker镜像,推送至docker仓库。

4、Jenkins执行shell,连接到服务器上,拉取刚刚build的docker镜像并运行。

5、发布完成后,通过邮件通知测试人员。

资源相关:

git服务 | github |
-|- jenkins | jenkins.test.com | 项目服务器 | 120.78.xxx.xxx |

jenkins服务和项目服务都是我们线上的测试服务器,所以地址就不公开了。


二、git相关

本文我用的是自己的githubhttps://github.com/opsonly,上面有一个用于测试的个人django的项目。

三、Jenkins设置

1、邮件设置

这里注意要设置Extended E-mail Notification,否则后面无法发送邮件!

  • 网站内容类型用的html,模板如下:
<!DOCTYPE html>    
<html>    
<head>    
<meta charset="UTF-8">    
<title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次构建日志</title>    
</head>    
    
<body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4"    
    offset="0">    
    <table width="95%" cellpadding="0" cellspacing="0"  style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">    
        <tr>    
            本邮件由系统自动发出,无需回复!<br/>            
             项目 ${PROJECT_NAME }已构建完成!</br> 
            <td><font color="#CC0000">构建结果 - ${BUILD_STATUS}</font></td>   
        </tr>    
        <tr>    
            <td><br />    
            <b><font color="#0B610B">构建信息</font></b>    
            <hr size="2" width="100%" align="center" /></td>    
        </tr>    
        <tr>    
            <td>    
                <ul>    
                    <li>项目名称 : ${PROJECT_NAME}</li>    
                    <li>构建编号 : 第${BUILD_NUMBER}次构建</li>    
                    <li>触发原因: ${CAUSE}</li>    
                    <li>构建状态: ${BUILD_STATUS}</li>    
                    <li>构建日志: <a href="${BUILD_URL}console">${BUILD_URL}console</a></li>    
                    <li>构建  Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li>    
                    <li>工作目录 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>    
                    <li>项目  Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li>    
                </ul>    

<h4><font color="#0B610B">失败用例</font></h4>
<hr size="2" width="100%" />
$FAILED_TESTS<br/>

<h4><font color="#0B610B">最近提交(#$SVN_REVISION)</font></h4>
<hr size="2" width="100%" />
<ul>
${CHANGES_SINCE_LAST_SUCCESS, reverse=true, format="%c", changesFormat="<li>%d [%a] %m</li>"}
</ul>
详细提交: <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a><br/>

            </td>    
        </tr>    
    </table>    
</body>    
</html>

2、创建一个任务(自由风格的软件项目)django-web,选择参数化构建

3、源码配置 · 4、触发器配置

根据自己情况而设置

5、构建配置

选择执行shell

注意:这里是整个流程的关键步骤,本文中是拉取github上的代码后,将其cp至另一个专用于build的目录,另外也将写好的Dockerfile文件也复制至该目录,然后完成docker镜像的build和push操作。

  • 项目服务器上的发布脚本如下
  • Dockerfile文件如下:
FROM python:3.7

ADD ./django-web ./app


WORKDIR ./app

RUN pip3 install -r requirements.txt

CMD ["python","manage.py","runserver","0.0.0.0:8000"]

6、构建后操作

在列表中选择“Editable Email Notification”。

注意:这里要选择Editable Email Notification,前面的邮件配置为Extended E-mail Notification,一定要对应起来,不然无法成功发送邮件(因为Jenkins还有自带的一个邮件通知,不过本文中没有使用)。

整个的配置流程大致就是这样子,可以根据实际情况再作调整,比如构建脚本和Dockerfile文件都还有很大的调整空间。

四、效果图

1、传入tag参数并构建项目

2、构建成功收到邮件通知:

3、打开刚刚构建成功的项目服务器的url,正常访问没有问题.

4、到项目服务器上查看一下启动情况:


五、总结

1、数据库问题: 因为上面的django项目用的mysql,而显然本文中mysql并没有用容器实现,如果想要容器化mysql,需要注意mysql和django项目之间的网络互通问题。django的mysql地址应填入容器mysql的容器名。

2、权限问题: 如果读者根据上面步骤来试验,可能会遇到mysql的权限问题,因为我的本地的mysql服务已加入了root@’%’账号,如果你是初始化的mysql,会出现连接失败的问题。解决方法很简单,就是根据情况添加特定的mysql账号。


喜欢我写的东西的朋友可以关注一下我的公众号,上面有我的学习资源以及一些其他福利。:Devops部落

© 著作权归作者所有

opsonly
粉丝 0
博文 7
码字总数 8286
作品 0
深圳
运维
私信 提问
.NET Core微服务之基于Jenkins+Docker实现持续部署(Part 1)

Tip: 此篇已加入.NET Core微服务基础系列文章索引 一、CI, CD 与Jenkins   互联网软件的开发和发布,已经形成了一套标准流程,最重要的组成部分就是持续集成(Continuous integration,简称...

Edison Chou
2018/08/11
0
0
从零开始搭建Jenkins+Docker自动化集成环境

本文只简单标记下大概的步骤,具体搭建各个部分的细节,还请自行搜索。第一、二部分只是对Jenkins和Docker的简单介绍,熟悉的同学请直接跳到第三部分。 Jenkins可以帮你构建一个自动化的持续...

林杰
2016/09/05
0
0
基于Jenkins,docker实现自动化部署(持续交互)【转】

前言 随着业务的增长,需求也开始增多,每个需求的大小,开发周期,发布时间都不一致。基于微服务的系统架构,功能的叠加,对应的服务的数量也在增加,大小功能的快速迭代,更加要求部署的快...

sunsky303
2018/06/21
0
0
快速部署Test-Driven Development/Debug环境

什么是Test-Driven Development Test-Driven Development 测试驱动开发,这个词儿各位技术大大必定耳熟能详,我作为一个曾经的Develop, ops,现在的DevOps从业者,这次想来跟大家聊聊Test-Dr...

力谱宿云
2016/05/11
235
0
我们应该如何基于容器来进行软件的持续交付(二)?

概述 接着上一篇的内容,我们有讲到“持续交付是文化,自动化是基石,垮职能团队协作是根本”,本文将以软文的形式介绍持续交付平台WiseBuild结合Rancher容器管理平台我们是如何进行跨职能团...

wise2c
2016/12/26
85
0

没有更多内容

加载失败,请刷新页面

加载更多

双因素认证绕过的钓鱼工具

研究人员发布了两个工具——Muraen和NecroBrowser。它们可以自动绕过2FA进行钓鱼攻击,大多数防御措施都无法抵御它们。 渗透测试人员和攻击者为他们的武器库添加了一个新的工具,这种工具可以...

Linux就该这么学
31分钟前
1
0
java代码和js两种方式判断浏览器是否是IE11

java代码判断浏览器是否是IE11 HttpServletRequest request = ServletActionContext.getRequest();String agent = request.getHeader("User-Agent");//判断是IE浏览器而且不是IE11的时......

平凡三度
35分钟前
1
0
2019 Vue开发指南:你都需要学点啥?

转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 原文出处:https://dzone.com/articles/vue-development-in-2019-what-you-need-to-know 如果...

葡萄城技术团队
37分钟前
0
0
[gitlab]登录页定制

Administrator - 设置 https://blog.csdn.net/weixin_43606948/article/details/85222755 支持markdown,用###...

Danni3
45分钟前
2
0
IT兄弟连 Java语法教程 编写Java源代码

现在我们来一步一步的编写第一个Java程序,鼎鼎大名的“HelloWorld”。 编写Java源代码 编写Java源代码可以使用任何无格式的文本编辑器,在Windows操作系统上可以使用记事本、Edit Plus等程序...

老码农的一亩三分地
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部