SAPLink是一个帮助人们分享开发内容的工具。通过它,人们可以将ABAP开发对象从一个系统打包下载、再上传到另一个系统中。对于各种类型的开发者,它都可以起到作用:
- 有的开发者喜欢在不同的项目中复制相似的程序、修修改改以实现快速实施。
- 有的开发者野心勃勃,希望开发自己的特定问题解决方案。
- 有的开发者希望从网络得到现成的示例程序,帮助自己学习。
恐怕绝大部分ABAP开发者都使用过或者听说过SAPLink,因此这里不再对它的做过多介绍。但是,也许有一部分人还不了解他的替代品:abapGit。本文试图解释,为什么我们应该是用abapGit替代SAPLink。
本文链接:https://www.cnblogs.com/hhelibeb/p/12988213.html
转载请注明
SAPLink的局限性
SAPLink的基本功能是把指定的开发对象序列化成为特定格式的文件,以及反过来把文件反序列化在系统中生成相应的开发对象。这一功能的概念在2020年的今天并不过时,但在具体的实现上,它是有一些问题的。
安装成本
SAPLink的安装需要遵循一些步骤,对于新人来说可能不是特别简单。我已经多次遇到SAP系统中的SAPLink不可用的情况,并被相关开发人员告知“不知道为什么不能用,可能是安装问题”。
功能不完善
越过了安装问题后,另一个难关是在实际使用中它不时会出现一些问题,有时是不支持某种类型的开发对象,需要安装插件,有时是导入中的dump,有时是导入后的对象错误。
无人维护
软件总会有不完美的地方,但如果没有了维护者,那就意味着它的各种问题不会再得到改善。如今,当我们访问原本是SAPLink的网站saplink.org,我们会被重定向至一个Github页面:https://github.com/sapmentors/SAPlink,由此我们可以得知这一项目其实已经不再被维护,而它的继任者为abapGit。
abapGit的优势
abapGit继承了SAPLink的基本功能——将开发对象上传下载,同时有着更多的优势。
易于安装
abapGit是一个单文件报表程序,因此开发者只需要在SE38新建文件,复制粘贴代码,激活即可安装abapGit。(这一点在新版的abapGit中稍有变化,不过整体来说难度还是很简单)
丰富的对象支持
abapGit支持上百种开发对象,而且它的表现十分可靠,对于常用的开发对象如类、数据字典、函数组、屏幕,我从未见过它出错。
稳定的维护者
abapGit是迄今为止最大的ABAP开源项目,它有着90+贡献者,3000+的提交次数,100000+行代码,项目的所有者larshp是我见过的精力最旺盛的ABAP开发者。这意味着abapGit可以持续地发展和改进,用户也可以为自己遇到的问题提issue请求协助。
良好的生态
abapGit得到了广大开发者和SAP的支持,通过abapGit开发者可以利用丰富的ABAP开源资源,也可以参与其中,贡献自己的项目、代码或思考。很多大公司在使用abapGit,包括SAP本身。你甚至可以在SAP的官方文档找到abapGit的中文教程:使用 abapGit。
Q & A
一些常见问题。
Git是什么,Github又是什么?
Git是一种分布式版本管理系统。
abapGit是用于处理SAP开发对象的Git客户端,下载/上传开发对象是它的功能之一。
Github是一个网站,它提供了代码仓库的功能,很多人使用Github来在线存储/分享代码,目前大部分ABAP开源项目会在Github发布。
服务器能访问外网是使用abapGit的必要条件吗?
不是,尽管abapGit提供了方便的在线模式,开发者依然可以通过离线模式像使用SAPLink那样通过上传下载文件的方式导出和导入开发对象。
如果开发者所在的公司防火墙内有Git代码仓库,比如自己搭建的Gitlab,也可以通过abapGit连接它,把代码传输到上面。
abapGit会导致我的代码泄露吗?
有人怀疑使用abapGit之后,自己的代码可能会不声不响地出现在Github之类的网站上。在看过上一个问题后,有这种疑问的读者应该会明白这是不可能的。
abapGit就像一个运钞车,它可以方便地运输大量钞票,但这不代表车上的钞票会自动跑到汽车交易平台。运到何处,司机(开发者)可以自行控制。
也可以通过权限控制,限制能使用abapGit的用户。
我要怎样安装abapGit?
上文已经说过,abapGit是一个单文件报表程序,因此开发者只需要在SE38新建文件,复制粘贴代码,激活即可安装abapGit。代码可以从官方文档获取:
https://docs.abapgit.org/guide-install.html
怎样利用开源资源?
前往github.com或dotabap.org查找你想用的东西,比如geohash,使用clone or download下载zip包,
然后在abapGit中create-import-pull即可。参考官方文档:
https://docs.abapgit.org/guide-import-zip.html
abapGit有什么缺点吗?
在深入应用abapGit之后,一些开发者提出过使用它时遇到的一些问题,比如:
- 由于SAP开发模式的特殊性,很难使用Git的分支功能。参考《abapGit分支策略》,这篇文章的英文原文中有很多讨论。
- abapGit对对象的上传下载是基于包的,这意味着如果开发者想上传下载的开发对象是跨包的,那么可能需要处理包含这两个包的父包。除非包与包之间的隔离很好(这在二次开发中很少见),那么最终可能会演变成必须有一个包含所有对象的总包,可以想象,上传下载这个总包会花费大量的时间...
- 少数类型的对象没有被支持。
但这些问题基本都是在一些复杂的使用场景才会出现,而且社区也在试图解决。它们丝毫不影响abapGit替代SAPLink的能力。
扩展阅读:
abapGit Branching Strategy Discussion
How we do ABAP code review using abapGit