一.jenkins+github+gradle 实现android自动化打包全攻略(MAC版)

小编 2026-06-23 阅读:1895 评论:0
折腾了好几天,今天终于实现了第一个Android项目的自动化打包,过程比较的艰辛,参考了大量的资料,基本都没能说的很全,当中的坑比较多,还是自己总结下吧!OK,闲言少叙,咱们直接上攻略(文章比较长)一.环境说明搭建机器:一台Mac Book...

折腾了好几天,今天终于实现了第一个Android项目的自动化打包,过程比较的艰辛,参考了大量的资料,基本都没能说的很全,当中的坑比较多,还是自己总结下吧!OK,闲言少叙,咱们直接上攻略(文章比较长)

一.环境说明

搭建机器:一台Mac Book Pro 开发工具:Android Studio 2.1.2(mac版本) 开发环境:OS X EI Capitan 版本 10.11.5 jenkins版:V1.647

(特别注意:我用的是V1.647,如果使用其他版本可能导致一些未知的BUG)

比如我之前用了最新的2.10版本,就导致了一个很奇葩的问题,找了很多资料都没有解决

2.10.png

所以还是用老版本吧,比较稳定点。

二.环境搭建

1.Android adb 命令配置

关于Android整个开发环境的搭建,什么SDK的下载安装,这里我就不详细叙述了,作为一个Android开发人员这个是基本技能了。 我主要说下adb命令配置 第一步:打开终端iTerm

iTerm.png

(广告插入,想要这个工具,可以看我之前的一篇文章:iOS程序猿这些工具你值得拥有http://www.jianshu.com/p/4b7e65f2677c) 第二步:输入touch .bash_profile(创建文件) 第三步:open -e .bash_profile(打开文件) 在弹出的文件中,输入Android SDK platform-tools的路径 格式为:export PATH=${PATH}:路径地址

1,2.png

第四步:输入source .bash_profile

第五步:输入adb(校验是否配置成功)

adb配置成功.png

2:配置gradle命令

通过brew命令进行安装:brew install gradle (关于brew命令的安装,可以参考这篇文章http://www.jb51.net/os/MAC/101860.html

安装命令.png

输入gradle -version校验是否配置成功

配置成功!.png

3:安装jenkins

通过brew install jenkins进行安装

安装jenkins.png

启动jenkins.png

通过浏览器访问(终于看到小老头了,哈哈)

浏览器访问.png

注意: 不要通过pkg安装,可能导致比较奇葩的问题 不要通过pkg安装,可能导致比较奇葩的问题 不要通过pkg安装,可能导致比较奇葩的问题

5669E035-E9B1-4428-8D44-0AB5043EDCE0.png

至于为什么,我也不知道,文末我会详细叙述下那个奇葩的BUG,还请大神指导

4:jenkins环境配置

a.安装相应的插件

Git Plugin Gradle Plugin Android Lint Plugin

1.png

2.png

b.环境变量配置

配置Android SDK路径

1.png

2.png

5:新建一个github的android项目

https://github.com/andli0626/jenkins-test-for-android-studio.git 至此,前期准备都准备完毕了

三.项目实战

1.新建一个自由风格的软件项目

1.png

2.配置git地址

2.png

我们先立即构建下,提示构建成功

构建成功.png

那么构建后的项目在哪里呢? 通过系统管理->系统设置->主目录 点击高级,可以查看到

查看目录.png

具体路径 /Users/xxx/.jenkins/jobs/Android_Test

完整路径.png

3:编译配置(很关键)

上面虽然编译成功了,但是你发现根本没有看到APK文件,所以还需要进行下面的配置:增加构建步骤

增加构建步骤.png

设置build.png

配置完成,点击立即构建,查看APK所在的路径 (注意:这个APK的生成路径是默认的不需要在jenkins中配置)

APK生成路径.png

OK,一个简单的打包就完成了。 后续需要解决如何进行自有签名的打包,如何发布APP? 未完待续。。。

等等楼主,貌似Gradle命令你还没说 使用gradle命令可以自己build项目啊

Paste_Image.png

参考资料

http://www.jianshu.com/p/8723777a32c4 (感谢maisie0731答疑解惑) http://www.jianshu.com/p/c90e21bf4e23 http://blog.csdn.net/voiceofnet/article/details/45197883 遇到的坑总结 http://blog.csdn.net/itfootball/article/details/45023805 http://blog.csdn.net/hwhua1986/article/details/48155163

附录:遇到一个很奇葩的BUG

使用最新版本jenkins 2.10,遇到一个很奇葩的BUG

Paste_Image.png

找了很多的解决方案,都不行

明明此路径下有android sdk

Paste_Image.png

明明系统设置里配置了全局变量

0R6D8${W6EYX}(Y}{X$8~@0.jpg

明明配置的SDK路径和Android Studio是一致的

Paste_Image.png

难道是没有权限???修改SDK目录的读写权限

  1. cd 你的文件夹路径的上一级目录。
  2. sudo chmod -R 777 你的文件夹名。
  3. 输入密码。 4.成功。

Paste_Image.png OK,权限也有了,然并卵,还是不行

只能翻墙,找google了,找来找去找到这么一条

Paste_Image.png

好吧,本地删除清理干净jenkins,通过brew install jenkins重新安装

好神奇,真的可以自动打包了

但是为什么呢???(可能是2.10的BUG吧。。。) 有大神知道的,欢迎留言,答疑解惑,感激不尽!

image

版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表