前文中我们在 TeamCity 中创建了一个项目 HelloApp,并在这个项目中创建了一个名为 HelloAppDailyBuild 的Build 用来编译 demo 程序。本文我们将详细介绍 Build 中的基本配置。下图是 Build 基本配置的概览:

Name

Build 配置的名称。

Build configuration ID

Build configuration ID: 在系统中标识该 Build 配置,自动生成的规则是:项目名称 +下划线 + build 配置名称。
比如要导航到一个 build 配置的页面, URL为:
http://xxxx/viewType.html?buildTypeId=HelloApp_HelloAppDailyBuild
最后一个参数就是 Build configuration ID。这个ID非常重要,我们使用 urls, REST API 向服务器请求信息时,都要使用它。在服务器上,它还作为一些配置文件的目录名称。

Description

作为描述信息,Description 会显示在 build name 的后面:

Build number format

我们可以为 build number 指定一个格式。不同的用户总是有不同的需求,如果您想要 build number 显示为一个自增的整数,就可以把 build number 指定为 %build.counter%。build.counter 是由 TeamCity 来维护的,您也可以手动指定它。设置为 %build.counter% 的 build number format 看起来是这个样子:

我们还可以指定为:
%build.vcs.number.<VCS_root_name>%
或者
%property.name%
这些都是 TeamCity 维护的一些变量。一个完整的例子看起来像这个样子 :
1.0.%build.counter%.%build.vcs.number.My_Project_svn%
注意,最好是保持 build number 的唯一性。所以应该把 build counter 加入到 build number format 中。
如果想用日期做 build number 该怎么办,如果还要显示 build 在每天中的序号呢?遗憾的是默认情况下我们没办法完成这样的需求,但是 TeamCity 提供了很好的扩展能力。我们可以写一个插件了实现这样的功能:

Build counter

Build 次数的计数器,您也可以手动设置它。但您做好清楚的知道自己在干什么。

Artifact paths

收集 build 产物需要通过指定 Artifact paths 来完成。我们可以把产物的路径分为两类:准确的路径和通过模式匹配获得的路径。

准确的路径

如果您知道 build 产物的准确路径,就可以直接写产物的路径。
还可以通过 teamcity 的工具进行选择:

通过模式匹配来指定路径

可以通过新行或者逗号来分隔不同的模式匹配规则如:

[+:]source [=> target]

这个规则把满足条件的文件加入到产物中。

-:source [=> target] 

这条规则则是把满足条件的文件从产物中移除。

方括号围起来的参数是可选的。规则根据右面的部分进行分组,根据出现的顺序依次起作用,如:

+:**/* => target_directory
-:**/folder1 => target_directory

表示除了 folder1 下的内容,把其他所有内容加入到产物中。

下面是详细的格式 :

file_name|directory_name|wildcard [ => target_directory|target_archive ]

file_name 指定产物文件相对于 build checkout directory 的路径。
directory_name 指定某个目录相对于 build checkout directory 的路径。目录下的所有文件和子目录都会被作为产物。产物中文件在目录中的结构保持不变。但是目录 directory_name 本身并不包含在产物中。
wildcard(通配符) 收集符合 Ant-like 的通配符匹配的文件作为产物 (仅支持 "*" 和 "**")。通配符要出现在相对于 build checkout directory 的路径中。符合条件的文件在产物中的路径会保持原来的路径结构。
还可以在收集产物的规则中使用参数。参数可以是 TeamCity 内置的变量也可以是用户自己定义的变量。

=> 后面的部分是可选的。=> 后面跟的目录名可以用来指定产物文件所存放的目录。
如果没有设置目标目录,那么产物会被放置在 build 产物的根目录下。
注意,目标路径不能是绝对路径。非相对的路径会在build时产生错误。
target_directory 收集的产物文件会被放到这个目录下。
target_archive 把产物打包后归档文件的路径。支持的归档文件格 式有 .zip,.7z,.jar,.tar.gz,.tgz。

下面是一些常用的例子:

install.zip
// 把 build checkout directory 目录下的所有文件放入压缩包 install.zip 作为产物。
dist
// 收集 build checkout directory\dist 目录下的所有内容作为产物。
target/*.jar
// 收集 build checkout directory\target 目录下的所有 jar 文件作为产物。
target/**/*.txt => docs
// 收集 build checkout directory\target 目录及其子目录下所有的 .txt 文件 作为产物。并把这些文件全部放入目标目录 docs 中。
reports => reports, distrib/idea*.zip
// 把 build checkout directory\reports 目录中的内容放入产物中的 reports 目录下。
// 把 build checkout directory\distrib 目录下符合 idea*.zip 条件的文件放到产物的根目录下。
// 我们还可以指定产物在 zip 归档文件中的位置,如:
results\result1\Dir1\Dir2 => archive.zip!results/result1/Dir1
// Dir2 目录中的内容将添加到归档文件中的 results/result1/Dir1 目录下。
// 产物中相同的归档文件名称可以被使用多次,如:
+:*/*.html => report.zip
+:*/*.css => report.zip!/css/
-:*/*.txt => report.zip

Build options

Build options 为我们提供了另外一些功能。

Hanging Build Detection

探测挂起的 build,TeamCity 能够探测可能是被挂起的 builds。
什么样的 build 被认为是被挂起的 build 呢?当一个 build 的执行时间明显的超过了系统估计的平均执行时间,并且在超过预估时间后 build 也没有发出过消息,此时就认为 build 处于挂起状态。TeamCity 会把已经运行过的 build 时间取平均值,从而估算出平均运行时间。当我们订阅通知时 TeamCity 系统的通知时,可以把 挂起作为一个条件。这样当挂起发生时我们就会收到通知。

Allow Triggering Personal Builds

这个功能允许用户使用未提交到代码库的代码做build,但是需要开发工具的支持。

Enable Status Widget

启用状态部件,这个选项让我们可以获得最后一次 build 的信息,而不需要要使用认证信息。需要注意的是,除了最后一次 build 的信息,我们其实还可以获得任何一次 build 的信息。但是仅限于获得 success/failure/internal error/cancelled 这几种信息。
我们可以通过不同的方式来获得信息,比如 HTML status widget 和 REST API。
下面我们看一下如何把 Build 信息嵌入到您的网页上。
先启用 “enable status widget”:

创建一个 html 网页,在 head 中加入:

<style type="text/css">
@import "<TeamCity_server_URL>/css/status/externalStatus.css";
</style>

在 body 中加入:

<script type="text/javascript" src="<TeamCity_server_URL>/externalStatus.html?js=1&buildTypeId=xxx">
</script>

请用您的 TeamCity 服务器地址更换上面字符串中的占位符,并且用有意义的 Build configuration ID 替换 xxx。然后在浏览器中打开看看:

Limit Number of Simultaneously Running Builds

设置一个 build 可以同时运行的最大数。
主要是防止所有的 build agent 同时被一个 build 全部用光。

TeamCity : Build 基本配置的更多相关文章

  1. TeamCity : Build 版本控制系统配置

    VCS (版本控制系统) 是用来跟踪项目源文件版本变化的系统.它还有其它的名字,比如 SCM(源代码管理).当前 TeamCity 内置支持的 VCS 类型有:Git, Subversion, Mer ...

  2. TeamCity : Build 失败条件

    允许用户配置 Build 失败的条件是很有用的功能,它是我们配置复杂 Build 流程的基础.TeamCity 为用户自定义 Build 失败条件提供了很好的支持.这些条件大体上可以分为两类,分别是: ...

  3. TeamCity安装和配置

    目录 TeamCity安装和配置 前言 持续集成(CI) TeamCity 环境 安装 配置TeamCity 项目构建 效果展示 TeamCity自动构建项目及集成IDEA(待更新......) 结束 ...

  4. r.js合并实践 --项目中用到require.js做生产时模块开发 r.js build.js配置详解

    本文所用源代码已上传,需要的朋友自行下载:点我下载 第一步: 全局安装  npm install -g requirejs 第二步: 1.以下例子主要实现功能, 1)引用jq库获取dom中元素文本, ...

  5. Ant之build.xml配置详解【转】

    原文:https://blog.csdn.net/mevicky/article/details/72828554 前言国内关于build.xml的配置资料太零散了,实在是受不了,故而将自己的笔记整理 ...

  6. Android开发之深入理解Android Studio构建文件build.gradle配置

    摘要: 每周一次,深入学习Android教程,TeachCourse今天带来的一篇关于Android Studio构建文件build.gradle的相关配置,重点学习几个方面的内容:1.applica ...

  7. 在build中配置resources,来防止我们资源导出失败的问题

    <!--在build中配置resources,来防止我们资源导出失败的问题--> <build> <resources> <resource> < ...

  8. 在build中配置resources, 来防止我们资源导出失败问题

    <!--在build中配置resources, 来防止我们资源导出失败问题--> <build> <resources> <resource> < ...

  9. Open Harmony移植:build lite配置目录全梳理

    摘要:本文主要介绍build lite 轻量级编译构建系统涉及的配置目录的用途,分析相关的源代码. 本文分享自华为云社区<移植案例与原理 - build lite配置目录全梳理>,作者:z ...

随机推荐

  1. Ubuntu 16.10 开启PHP错误提示

    两个步骤: 修改php.ini配置文件中的error_reporting 和 display_errors两地方内容: sudo vim /etc/php/7.0/apache2/php.ini er ...

  2. 工行ICBC_WAPB_B2C支付接口

    一. 前期准备 手机银行(WAP)B2C在线支付接口说明V1.0.0.6.doc 手机银行移动生活商户及门户网站js接口API.doc 支付组件ICBCEBankUtil.dll和infosecapi ...

  3. 纸箱堆叠 bzoj 2253

    纸箱堆叠 (1s 128MB) box [问题描述] P 工厂是一个生产纸箱的工厂.纸箱生产线在人工输入三个参数 n, p, a 之后,即可自动化生产三边边长为 (a mod P, a^2 mod p ...

  4. js数组去重几种思路

    在一些后台语言中都内置了一些方法来处理数组或集合中重复的数据.但是js中并没有类似的方法,网上已经有一些方法,但是不够详细.部分代码来源于网络.个人总计如下:大致有4种思路 1)使用两次循环比较原始的 ...

  5. Atitit.attilax软件研发与项目管理之道

    Atitit.attilax软件研发与项目管理之道 1. 前言4 2. 鸣谢4 3. Genesis 创世记4 4. 软件发展史4 5. 箴言4 6. 使徒行传 4 7. attilax书 4 8. ...

  6. Quartz

    Quartz是一个开源的作业调度框架,它完全由Java写成,并设计用于J2SE和J2EE应用中.它提供了巨大的灵 活性而不牺牲简单性.你能够用它来为执行一个作业而创建简单的或复杂的调度. eg: ja ...

  7. Xamarin.Android之ActionBar与菜单

    一.选项卡 如今很多应用都会使用碎片以便在同一个活动中能够显示多个不同的视图.在Android 3.0 以上的版本中,我们已经可以使用ActionBar提供的Tab来实现这种效果,而不需要我们自己去实 ...

  8. Hadoop3 在eclipse中访问hadoop并运行WordCount实例

    前言:       毕业两年了,之前的工作一直没有接触过大数据的东西,对hadoop等比较陌生,所以最近开始学习了.对于我这样第一次学的人,过程还是充满了很多疑惑和不解的,不过我采取的策略是还是先让环 ...

  9. 架构之路(九)Session Per Request

    前面的两篇反应很差:没评论没赞.很伤心啊,为什么呢?搞得我好长一段时间都没更新了——呵呵,好吧,我承认,这只是我的借口.不过,还是希望大家多给反馈.没有反馈,我就只能猜了:前面两篇是不是写得太“粗”了 ...

  10. C#对WebApi数据操作

    目标 简化并统一程序获取WebApi对应实体数据的过程,方便对实体进行扩充.原理就是数据服务使用反射发现数据提供者,处理好泛型就行. 相关传送门:Restful WebApi开发实践 先来看下最后的请 ...