更多精彩请直接访问SkySeraph个人站点:www.skyseraph.com
简单绘制了下Jenkins的一个流程,如下图:
IBM Developer上也有一个看似更复杂一点的图,如下图
持续交互流程图:
官网: https://jenkins.io/index.html
下载: http://mirrors.jenkins-ci.org/war/latest/jenkins.war
安装:
启动
插件安装
操作: Manage Jenkins -> Manage Plugins -> Available -> Search -> Click to install,如下图所示
实用插件
操作: Manage Jenkins -> Configure System
SMTP详细配置请参考 How to send Email at every build with Jenkins
配置编译参数
例如,如果需要打包者自行选择打包类型,如需要编译Release/Debug/Test等不同版本的包,那需要配置Jobs的编译参数,配置方法如下图所示:
你还可以配置一些其它参数,例如:
配置完后,build界面中就会出现,如下如所示:
How to configure a single Jenkins job to make the release process from trunk or branches?
配置匿名用户权限
后面打包的应用发布时,如果懒得自己搭建服务器,就用Jenkins的,但发布出去的链接需要登录才能访问,这时候你可以设置匿名用户的访问权限,这样匿名用户可以下载访问你提供的应用链接了,非常取巧的方法,如下图:
配置SSH
操作: Manage Jenkins -> Credentials -> Global credentials (unrestricted) -> Add Credentials
新建Job
在Jenkins中,所有的任务都是以”Job”为单位的。在进行操作前,你需要新建一个Job,Job新建比较简单,只需要在Jenkins管理的首页左侧,点击“New Job”,一般选择free-style software project,再输入Job的名字即可。
配置Gitlab
在新建的任务(Jobs)中,Gitlab源码配置如下图:需要输入git仓库和build分支,公钥使用上面配置SSH生成的公钥。
Jenkins支持多种触发器配置,包括:
定期进行构建(Build periodically),定时器使用示例如下:
H(25-30) 18 * * 1-5: 工作日下午6点25到30分之间进行build
H 23 * * 1-5:工作日每晚23:00至23:59之间的某一时刻进行build
H(0-29)/15 * * * *:前半小时内每隔15分钟进行build(开始时间不确定)
H/20 * * * *:每隔20分钟进行build(开始时间不确定)
根据提交进行构建(Build when a change is pushed to GitHub)
Jenkins支持多种编译配置方式,包括:
对于iOS应用的构建,如果选择Xcode方式构建,需要配置好开发者证书,具体参考后面签名和整数问题。
推荐使用Exceute Shell方式,简单有效。
Artifacts和邮件通知配置,参考下图
可借助Email Extension Plugin 插件进行详细配置,具体可参考此文
发布
iOS的发布可能希望用到OTA,可参考此文
这里分享一个我写的shell脚本模板(已开源),可以用于iOS的plist文件自动创建以及OTA简单发布页面的自动创建,参考此链接获取源码, 欢迎Star.
自动生成一个简单HTML界面,如下图,点击Install即可安装:
注意,这里iOS7.1以后限定必须要要用https,所以需要对jenkins设置下https,参考下面”后记” 中的Jenkins Https设置
Last Show
构建成功后最终的结果如下如所示:
查询Jenkins Https相关命令:
java -jar jenkins.war –help | grep -i https
说明:下面以Mac为例.
KeyStore方式
keytool -genkey -keyalg RSA -alias selfsigned -keystore keystore.jks -storepass 密码 -dname "cn=WEB"
java -jar jenkins.war --httpPort=-1 --httpsPort=8080 --httpsKeyStore=/目录/keystore.jks --httpsKeyStorePassword=密码
Certificate方式
1. openssl genrsa -out server.key 1024
2. openssl req -new -key server.key -out server.csr
3. openssl x509 -req -in server.csr -signkey server.key -out server.crt
java -jar jenkins.war --httpsPort=8088 --httpsCertificate=/path/server.crt --httpsPrivateKey=/path/server.key
实用参考
文章持续更新地址,请移步查阅
By SkySeraph-2016
原文:http://blog.csdn.net/zgzhaobo/article/details/52002181