Salesforce学习之路-developer篇(二)利用Jenkins和Bitbucket实现Salesforce的CI/CD功能
上文提到,基于CRM的二次开发是必不可少的,但是在实际项目中CI/CD是不可忽略的一个重要部分,与传统的Java,Python项目不同,如果对Salesforce进行持续集成和持续部署呢?
结合找到的各种资源,并加上之前Java和Python的CI/CD经验,这里设计了一套简单的模版,如有错误,望各位大佬斧正。
1. 系统结构图
这里的设计,主要利用了Ant的代码迁移功能。
详细知识可参考:https://developer.salesforce.com/docs/atlas.en-us.daas.meta/daas/meta_development.htm
2. Jenkins配置
这里选择构建一个自由风格的软件项目
2.1 源码管理
这里选择Git,找到对应的Git库,然后clone其HTTP的链接,将其复制至Repository URL
2.2 创建凭据
创建凭据时,你可以在Credentials后面点击Add按钮,然后选择对应的项目库,输入用户名和密码,cs-jenkins.gen/******。
注意:这里添加的凭据仅适用于该item,如果想要创建一个全局的凭据,需要在Jenkins项目的凭据栏添加全局凭据。当然添加的方式有多种,最常用的便是用户名/密码与公钥/私钥方式,如果感兴趣可以自行查阅相关资料。
2.3 Git添加用户权限
【Repository Setting】 --> 【Repository Permissions】 --> 【User access】
点击git库设置(左下角),然后点击库权限,添加可访问用户cs-jenkins.gen
注意:除了添加单个用户外,还可选择添加某个用户组,选择Group access即可。
2.4 构建触发
接触过Jenkins的都知道,它有多种触发方式,但业内常用的方式一般为两种:定时器和轮询SCM。
定时器:顾名思义,每隔一段时间便从Git上拉取代码,然后触发构建。
轮询SCM:每隔一段时间,便向Git发送查询信息,查看指定分支代码是否改变,如果不变则跳过,如果代码变化,则触发构建。
这里选择轮询SCM,并且设置每隔五分钟便向Git查询一次(时间太长,会导致CI不及时;时间太短,调用API过于频繁造成性能损耗)
2.5 构建
构建模块,是jenkins的核心,不同于Java的Mvn打包的构建方式,这里采用Invoke Ant,直接将Sandbox1的代码迁移到Sandbox2中。
这里分为两步:ant迁移代码,将Jenkins工作空间代码提交至Git
- Invoke Ant
关于ant在salesfroce中是如何做到代码迁移的,请参考:https://developer.salesforce.com/docs/atlas.en-us.daas.meta/daas/meta_development.htm
build.xml
<project name="Code Backup Without Folders" default="retrieve" basedir="." xmlns:sf="antlib:com.salesforce">
<property file="build.properties"/>
<property environment="env"/> <taskdef uri="antlib:com.salesforce"
resource="com/salesforce/antlib.xml"
classpath="ant-salesforce.jar"/> <target name="deploy">
<sf:deploy
username="${Sandbox2.username}"
password="${Sandbox2.password}"
serverurl="${sfProduction.serverurl}"
deployRoot="${Sandbox2.retrieveTarget}"
runAllTests="true" />
</target>
<target name="retrieve">
<git command='checkout' dir="">
<args>
<arg value="${git.release}" />
</args>
</git>
<git command="remote" dir="">
<args>
<arg value="set-url" />
<arg value="origin" />
<arg value="https://${git.userName}:${git.password}@bitbucket/scm/cs-digitalization/sp.git" />
</args>
</git>
<git command="pull" dir="" />
<sf:retrieve username="${Sandbox1.username}"
password="${Sandbox1.password}"
serverurl="${sfSandbox.serverurl}"
retrieveTarget="./"
unpackaged="package.xml"/>
<echo message="Commiting all changes with message ${git.commitMessage}" />
</target> <macrodef name="git">
<attribute name="command" />
<attribute name="dir" />
<element name="args" optional="true" />
<sequential>
<echo message="Executing Command in folder @{dir}" />
<echo message="git @{command}" />
<exec executable="git" dir="@{dir}">
<arg value="@{command}" />
<args/>
</exec>
</sequential>
</macrodef>
</project>
- Execute Shell
if [ -n "$(git diff)" ]
then
git add .
git commit -m "Commiting all changes with message from Sandbox"
git remote set-url origin https://cs-jenkins.gen:******@bitbucket/scm/cs-digitalization/sp.git
git push -u origin release/dev
else
echo "Nothing changed"
fi
3. FAQ
虽然上述流程并不复杂,甚至可以说是比较简单,但是在其中也着实踩了几个坑,这里简单提下遇到的问题以及解决的方案。
3.1 Problem: failed to create task or type antlib:com.salesforce:retrieve
原因:由于本人用的jenkins是公司提供的平台,是由多个实例组成的集群,所以每次触发时并不在某台固定的VM上,并且本人没有直接访问服务器的权限。说来可能运气比较差,遇到的几台VM上都没有成功装ant-salesfroce.jar包,故手动下载ant-salesforce.jar包,并上传是代码工程中,这样不管在哪台VM工作,在向Git拉取代码时,并会拉取该Jar包(22.6M)。当然,这是会增加拉取代码时间,所以若有访问Jenkins服务器权限的话,建议在服务器中直接安装。
解决方案:
1)下载ant-salesforce.jar包,并上传至代码工程。
下载链接:https://gs0.salesforce.com/dwnld/SfdcAnt/salesforce_ant_46.0.zip
2)build.xml中重定义依赖包位置。
<taskdef uri="antlib:com.salesforce"
resource="com/salesforce/antlib.xml"
classpath="ant-salesforce.jar"/>
3.2 Problem: could not read Username for 'https://bitbucket.com': No such device or address.
原因:虽然在jenkins中源码管理的地方配置了凭据,但这只用于链接,在提交时并没有使用该用户,所以相当于匿名提交,这是Git所不允许的。
解决方案:手动设置git的remote url,并在url中显式配置用户名和密码。
git remote set-url origin https://cs-jenkins.gen:******@bitbucket/scm/cs-digitalization/sp.git
这样,一个基于Jenkins的Salesfroce CI/CD便完成了。上述若有模糊或错误之处,还望各位不吝之处,抱拳了。
Salesforce学习之路-developer篇(二)利用Jenkins和Bitbucket实现Salesforce的CI/CD功能的更多相关文章
- Salesforce学习之路(四)利用Jenkins和Git实现Salesforce的CI/CD功能
上文提到,基于CRM的二次开发是必不可少的,但是在实际项目中CI/CD是不可忽略的一个重要部分,与传统的Java,Python项目不同,如果对Salesforce进行持续集成和持续部署呢? 结合找到的 ...
- Salesforce学习之路-developer篇(一)利用VS Code结合Git开发Salesforce
Part 1: 从Git中克隆代码到本地 git clone https://github.com/git/git Part 2: 在VS Code中安装Salesforce和Git插件 在VS Co ...
- Salesforce学习之路-developer篇(三)利用Visualforce Page实现页面的动态刷新案例学习
Visualforce是一个Web开发框架,允许开发人员构建可以在Lightning平台上本地托管的自定义用户界面.其框架包含:前端的界面设计,使用的类似于HTML的标记语言:以及后端的控制器,使用类 ...
- Salesforce学习之路-developer篇(五)一文读懂Aura原理及实战案例分析
1. 什么是Lightning Component框架? Lightning Component框架是一个UI框架,用于为移动和台式设备开发Web应用程序.这是一个单页面Web应用框架,用于为Ligh ...
- Salesforce学习之路-developer篇(五)Aura组件原理及常用属性
很喜欢曾经看到的一句话:以输出倒逼输入.以输出的形式强制自己学习,确实是高效的学习方式,真的很棒.以下仅为个人学习理解,如有错误,欢迎指出,共同学习. 1. 什么是Lightning Componen ...
- Salesforce学习之路-developer篇(四)Visualforce结合Reports展示图表
Salesforce作为一款CRM系统,个人觉得最重要的环境便是在于数据的展示和联动,而Salesforce也本身提供了相当强大的功能,Report在展示图表的方面十分强大,前段时间更是宣布以157亿 ...
- Salesforce学习之路(三)利用VS Code结合Git开发Salesforce
在前面说了一些有关Admin的知识,但实际开发运用中,仅凭Admin的配置很难满足项目的定制化需求,因此基于CRM的二次开发则应运而生. 由于国内资料相对较少,所以很多入门新手无处下手,那这里就简单介 ...
- Salesforce学习之路-admin篇
Salesforce是一款非常强大的CRM(Customer Relationship Management)系统,国外企业使用十分频繁,而国内目前仅有几家在使用(当然,国内外企使用的依旧较多),因此 ...
- Salesforce学习之路(六)利用Visualforce Page实现页面的动态刷新功能
Visualforce是一个Web开发框架,允许开发人员构建可以在Lightning平台上本地托管的自定义用户界面.其框架包含:前端的界面设计,使用的类似于HTML的标记语言:以及后端的控制器,使用类 ...
随机推荐
- 数据算法 --hadoop/spark数据处理技巧 --(13.朴素贝叶斯 14.情感分析)
十三.朴素贝叶斯 朴素贝叶斯是一个线性分类器.处理数值数据时,最好使用聚类技术(eg:K均值)和k-近邻方法,不过对于名字.符号.电子邮件和文本的分类,则最好使用概率方法,朴素贝叶斯就可以.在某些情况 ...
- IntelliJ IDEA 从入门到上瘾教程,2019图文版!
前言:IntelliJ IDEA 如果说IntelliJ IDEA是一款现代化智能开发工具的话,Eclipse则称得上是石器时代的东西了. 其实笔者也是一枚从Eclipse转IDEA的探索者,随着近期 ...
- **p,*p和&p使用有感
*p两种使用情况: 1.定义指针变量,如char *p:这里p是一个变量,单单在这一点上与int a 无差别:但p这个变量特殊在其中只能存地址. 引申:对于char **p,p中存一个地址add1,a ...
- Liunx学习总结(八)--服务
什么是服务 服务是向外提供服务的进程,一般来说都会放在后台,既然要持续不断的提供外界随时发来的服务请求,服务进程就需要常驻在内存中,且不应该和终端有关,否则终端退出服务程序就退出了.另外,要能够接待外 ...
- 如何在Python中表示一个对象
关于我 一个有思想的程序猿,终身学习实践者,目前在一个创业团队任team lead,技术栈涉及Android.Python.Java和Go,这个也是我们团队的主要技术栈. Github:https:/ ...
- VScode 插件推荐与C/C++配置
以下是我经常用到的VScode插件.由于插件本身具有详细的配置和介绍,不对插件本身的安装配置进行说明,仅仅支出这些插件的主要功能.具体使用强烈推荐看一下安装插件后的说明,大多数的问题和设置都可以找到, ...
- 游戏客户端面试(Egret)
推荐阅读: 我的CSDN 我的博客园 QQ群:704621321 一.朋友面的一家公司 1.说下let,var,const. var定义的变量,没有块的概念,可以跨块访问, 不能跨函 ...
- C#数据结构_查找
查找:静态查找和动态查找. 衡量查找算法的最主要的标准是平均查找长度(Average Search Length,简 称 ASL).平均查找长度是指在查找过程中进行的关键码比较次数的平均值. 顺序查找 ...
- 王某人从0开始学习lorawan的笔记_1:最底层!IO驱动层,Gpio_t类
本来想介绍SX1276(与SX1278的操作完全相同,只是需要处理频段)的,但是这款芯片内容还是很丰富的,三言两语介绍不清,而且资料也很多就算了. 直接正面怼lorawan吧,怼到高地去,打爆lora ...
- JavaScript label语句
使用label 语句可以在代码中添加标签,以便将来使用. 以下是label 语句的语法: label: statement 下面是一个示例: start: for (var i=0; i < c ...