Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

时间:2023-03-08 16:28:47
Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins是一个可扩展的持续集成引擎,Jenkins非常易于安装和配置,简单易用,下面开始搭建dotnet持续集成环境

一、准备工作

1、系统管理--》管理插件--》可选插件中找到MSBuild Plugin, 安装插件 MSBuild Plugin

2、配置MSBuild(系统管理--》Global Tool Configuration--》MSBuild安装)

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

参数填写说明:

MSBuild Name 只是一个名称可以随便填,但建议填有点意义名称,例如:MSBuild_v4.0

Path to MSBuild 这个是安装MSBuild所在的路径,例如:C:\Windows\Microsoft.NET\Framework64\v4.0.30319\MSBuild.exe

3、邮件通知配置(邮件的发送者信息)

邮件通知需要配置两个地方,一处是在系统设置,一处是在job配置中的 构建后操作 Extended E-mail Notification与E-mail Notification节点配置:

系统管理--》系统设置 找到 Extended E-mail Notification(此插件需要安装,图中的部分信息需要点击 高级 按钮才能显示)

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

邮件通知节点配置(图中的部分信息需要点击 高级 按钮才能显示):

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

上面的配置是邮件的发送者的163邮件信息

说明:

SMTP server(SMTP服务器) :登录163邮箱进行获取( 设置--》POP3/SMTP/IMAP)

User Name(用户名):登录163邮箱的账号名称

Password(密码):163邮箱的 客户端授权码

登录163邮箱--》设置--》POP3/SMTP/IMAP

开启 服务POP3/SMTP/IMAP

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

选中上图的 开启 获得 授权码  此授权码就是  配置邮件通知时的密码

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

设置客户端授权码成功:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

系统管理员邮件地址配置 可以不配置:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

job里面邮件通知的配置(配置邮件接收者的信息)

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

进入配置:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

default Content 为邮件模板:

    <!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>
<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>项目描述:${JOB_DESCRIPTION}</li>
<li>构建编号 : 第${BUILD_NUMBER}次构建</li>
<li>SVN 版本: ${SVN_REVISION}</li>
<li>触发原因: ${CAUSE}</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>
</td>
</tr>
<tr>
<td><b><font color="#0B610B">变更集</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr> <tr>
<td>${JELLY_SCRIPT,template="html"}<br/>
<hr size="2" width="100%" align="center" /></td>
</tr> <tr>
<td>
<ul>
<li>历史变更记录 : <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a></li>
</ul> ${CHANGES_SINCE_LAST_SUCCESS,reverse=true, format="Changes for Build #%n:<br />%c<br />",showPaths=true,changesFormat="<pre>[%a]<br />%m</pre>",pathFormat="&nbsp;&nbsp;&nbsp;&nbsp;%p"}
</td>
</tr>
<tr>
<td><b>Failed Test Results</b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td><pre
style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">$FAILED_TESTS</pre>
<br /></td>
</tr>
<tr>
<td><b><font color="#0B610B">构建日志 (最后 9999999行):</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<!-- <tr>
<td>Test Logs (if test has ran): <a
href="${PROJECT_URL}ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip">${PROJECT_URL}/ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip</a>
<br />
<br />
</td>
</tr> -->
<tr>
<td><textarea cols="500" rows="100" readonly="readonly"
style="font-family: Courier New">${BUILD_LOG, maxLines=9999999}</textarea>
</td>
</tr> </table>
</body>
</html>

点击 advanced settings 进入高级设置:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

这里选择了成功和失败的情况下发送:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

现在开始进行搭建job

点击 新建

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

进入下图的界面:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

点击 OK 按钮后 进入一下页面

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

到处一个新的 job就新建完成了,下面开始配置job

点击 源代码管理(tab)--》选中Subversion

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

添加登录SVN账号和密码

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

最后 源代码管理(tab) 配置为:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

构建触发器(tab)此项是设置间隔多长时间去检查一次SVN的代码有没有变化,如果有变化则重新编译

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

构建环境(tab) 未研究此项配置有何作用,使用默认的,不做任何修改

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

构建(tab)此项设置编译方式、将站点文件拷贝到iis的站点目录下发布站点

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

说明:

/t:ResolveReferences;Compile /t:_CopyWebApplication /p:Configuration=Release /property:TargetFrameworkVersion=v4.0 /p:WebProjectOutputDir=D:\Jenkins_Publish\DEV_Metadata /p:OutputPath=D:\Jenkins_Publish\DEV_Metadata\bin

MSBuilder Version 为之前配置的 "MSBuild V4.0"

MSBuild Build File 是项目文件或者工程文件的名称

/t:Rebuild 表示每次都重建,不使用增量编译

/property:Configuration=Release 表示编译Release版本,

/p:WebProjectOutputDir=E:\Jenkins_Publish\DEV_Metadata表示网站发布文件的输出路径

/p:OutputPath=E:\Jenkins_Publish\DEV_Metadata\bin  表示项目Dll输出路径

/property:TargetFrameworkVersion=v4.0表示编译的目标是.NET 4.0

xcopy d:\Jenkins_Publish d:\JenkinsWeb /s/e/y/exclude:C:\Users\jie\Desktop\exclude.txt    站点的文件拷贝命令

d:\Jenkins_Publish 要拷贝的文件目录

d:\JenkinsWeb 拷贝文件到此目录下

/s 复制目录和子目录,除了空的。

/e 复制目录和子目录,包括空的。

/y 禁止提示以确认改写一个现存目标文件(如果文件存在则覆盖)。

/exclude:C:\Users\jie\Desktop\exclude.txt  /exclude 指定含有字符串的文件列表。如果有任何字符串与要被复制的文件的绝对路径相符,那个文件将不会得到复制。例如,指定如 \obj\ 或 .obj 的字符串会排除目录 obj 下面的所有文件或带有.obj 扩展名的件。exclude.txt文档是排除文件或者目录,如果有排除多种类型的文件或者目录,则用户换行分割

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

排除 .pdb后缀的文件,和web.config 文件

构建后操作(tab) 此项主要是配置邮件通知 将编译情况发送给开发者

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

编译错误时发送通知:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

编译成功时发送邮件通知:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

说明:

Recipient List :接收邮件的邮箱(如果有多个用英文逗号隔开)

Content :发送邮件的模板

    <!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>
<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>项目描述:${JOB_DESCRIPTION}</li>
<li>构建编号 : 第${BUILD_NUMBER}次构建</li>
<li>SVN 版本: ${SVN_REVISION}</li>
<li>触发原因: ${CAUSE}</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>
</td>
</tr>
<tr>
<td><b><font color="#0B610B">变更集</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr> <tr>
<td>${JELLY_SCRIPT,template="html"}<br/>
<hr size="2" width="100%" align="center" /></td>
</tr> <tr>
<td>
<ul>
<li>历史变更记录 : <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a></li>
</ul> ${CHANGES_SINCE_LAST_SUCCESS,reverse=true, format="Changes for Build #%n:<br />%c<br />",showPaths=true,changesFormat="<pre>[%a]<br />%m</pre>",pathFormat="&nbsp;&nbsp;&nbsp;&nbsp;%p"}
</td>
</tr>
<tr>
<td><b>Failed Test Results</b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td><pre
style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">$FAILED_TESTS</pre>
<br /></td>
</tr>
<tr>
<td><b><font color="#0B610B">构建日志 (最后 9999999行):</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<!-- <tr>
<td>Test Logs (if test has ran): <a
href="${PROJECT_URL}ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip">${PROJECT_URL}/ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip</a>
<br />
<br />
</td>
</tr> -->
<tr>
<td><textarea cols="500" rows="100" readonly="readonly"
style="font-family: Courier New">${BUILD_LOG, maxLines=9999999}</textarea>
</td>
</tr> </table>
</body>
</html>

到此已经job配置完成,下面来看看 构建结果

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境

构建成功

此次测试安装的插件:

Jenkins+MSbuild+SVN实现dotnet持续集成 快速搭建持续集成环境