基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

低代码开发和API快速开发

在谈低代码开发平台的时候我多次强调了对象模型和数据驱动的重要性,同时低代码开发平台不是零代码开发,对于复杂规则的实现仍然需要自己写代码来完成。

而对于自己写代码实现复杂规则,其核心还是基于类似云原生里面ServerLess的思路,即通过API接口和服务来实现上层应用和底层能力提供之间的解耦。那么如何快速地开发和发布API接口服务,如何对API接口进行组装和编排就成为了低代码开发平台不可缺少的一部分。

对于API快速开发和发布,既可以是一个独立的子产品,也可以是我们规划设计的整体低代码开发平台的一部分,但是核心都是基于对象建模和模型驱动的思路进行。

对于业界当前对于API快速开发,如何通过对象模型快速发布API接口,如何通过数据库的数据表和SQL快速灵活发布API接口,如何对API接口灵活组装和配置,并没有特别好的开源产品,因此在做我们自己的API快速开发平台的时候,更多还是借鉴了我们多年实施SOA项目,进行微服务架构实践的一些实际项目需求出发进行。

对于SOA项目实践,即对传统的SOA集成中的数据库适配,存储过程适配等能力转变为更加轻量易用的基于对象和数据库的接口发布。

而对于项目实践,经常会遇到和外部业务系统集成,需要开发自身接口的情况,那么通过API快速开发平台可以快速的通过可配置化的方式发布对外接口能力,同时实现基本的API接口管控和治理。

这也是我们自主研发基于数据驱动的API低代码开发平台的初衷。

API快速开发平台概述和应用场景

对于前后端分离的应用来说,后端应用主要是以API的形式对外提供能力,而在微服务架构盛行的当下,很多企业对于后端传统的应用程序已经做了打散和拆分,实现了微服务改造。如果一个企业的IT建设比较全的话,那么在管理域、业务域和运维域的传统信息化系统至少超过10个,全部经过微服务拆分改造后的微服务应用可能达到几十甚至上百个。如此多的微服务应用不仅运维管控存在问题,而且微服务应用的开发、变更、升级都会存在较大的时间和资金成本。

微服务运维管控的问题交给Devops,本章只为应对微服务应用开发变更带来的问题。目前业界提供了一个快速应对的解决方案—API开发设计平台,该平台能协助开发人员全程可视化、无代码快速创建API并发布,业务变更时快速更新API,分钟级完成微服务应用的产品开发部署。API开发设计平台真正降低了企业应用进行微服务改造的难度,对于开发设计人员来说是一个非常不错的工具。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

API开发设计平台的适用场景主要包括以下几个方面:

1.统一后端API设计/开发/测试平台:承担API的设计、开发、测试功能,可通过配置完成API的在线发布,业务人员同样可以熟练操作。

2.移动端API开发平台: 对于APP、微信、小程序、钉钉等前端应用,可作为统一后端API开发平台

3.前后端分离开发:对于前后端分离的业务系统,可作为后端API的开发平台

4.数据快速提取:能实现数据中台的数据能力发布,可作为数据快速提取平台

5.微服务架构开发:同样可作为业务系统 (OA、CRM、ERP、HR、MES)微服务改造与开发的基础平台。

对于API开发开发平台我们采用微服务架构进行开发,开发底层框架选择了JeecgBoot,并在该开源框架下做了一些优化处理和定制。

而对于API接口服务的开发,

首先来谈一下平台的整体技术架构,该平台底层框架采用JeecgBot,架构团队在JeecgBot的基础之上做过一些优化。对于服务的发布,平台采用了IBM开源轻量的Node-Red作为API在线发布的基础组件,使用FreeMaker开发模板作为微服务应用生成框架,并集成了DBApi产品的后端所有功能。其他技术框架包括Springboot swagger Mybatis lombok Redis Shiro Maven Vue等。

场景一:数据实体生成API的实现

在前面已经谈到,该API开发平台是基于对象建模和数据驱动的,因此核心是里面的元数据管理和数据实体定义。通过数据实体既可以向前生成API接口服务,又可以向后生成后台的数据库对象和数据表。

平台支持多数据源管理,支持连接主流的关系型数据库Mysql/Oracle/Sqlserver.支持连接的在线测试、密码加密、连接共享等功能。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

对象建模能力通过元数据管理来实现。元数据为最底层的原子数据对象,支持对元数据的基础管理能力,同时元数据本身又是建立数据实体的基础数据依赖,可通过关联多个元数据来构建多层数据实体。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

支持通过导入元数据的方式来建立多层数据实体(目前支持父/子/孙三层实体关系),可根据选择的数据源连接类型来生成数据库建表的SQL语句,并可直接在平台上对数据源连接的数据库生成数据表结构和表依赖关系。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

支持数据实体快速发布在线API,在线API发布支持公有和私有两种方式,私有API通过配置群组和Token值来限制访问;通过数据实体发布的API支持对该数据实体的新增/修改/删除/查询,操作的数据会同步读取或者写入数据实体对应数据源连接的库表中。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

在线API发布后形成Node-Red的流程,通过设计器可对流程进行拖拽修改;对于发布后的API,可直接在平台上进行测试。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

从上可以看到整个思路完全是基于对象建模驱动,通过对象建模来定义详细的实体对象模型和接口契约规范,一方面是定义的对象模型可以通过配置的数据源管理向后台生成数据库表,一方面是可以直接将对象模型发布为通用的Rest API接口服务。

同时发布的内容在后台会生成对应的Node-Red服务编排模板,如果对于发布的接口需要进行相关的修改和调整,也相当容易实现灵活定制和配置。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

场景一:数据库表和SQL直接发布API接口

如果你已经创建了数据库对象和数据表,那么你可以直接将数据表发布为Rest API接口,同时也可以自己定制参数化SQL语句,并将SQL语句发布为API接口服务。

对于数据库中已经存在的数据表,也可直接发布生成API。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

数据表API发布功能除了发布常用的对数据表的新增/修改/删除/查询API之外,还发布对数据表进行分页和条件查询的API;数据表API发布支持对发布后API的动态编排,公有私有配置、API端点的在线测试。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

SQL语句发布为API接口服务

可编写SQL语句发布在线API,在线API发布在当前服务器下,支持动态SQL的编写和发布,支持传入参数的定义、配置和SQL映射。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

2、通过SQL发布后的API可支持上线/下线操作、公有私有配置、在线API测试操作。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

场景四:基于YAML规范来开发发布API:

还有一种场景是首先进行了API接口契约规范的设计,然后在进行API接口的开发实现。那么在API契约确定清楚后,实际整个API接口就已经可以按规范进行发布。

因此我们API快速开发平台在功能实现中也集成了第三方API规范设计器,支持YAML/JSON格式规范的结构化设计。也集成了Swagger设计器,可灵活编写API规范文件。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

基于规范的API在线发布,可按步骤填写配置完成API的开发发布。支持对规范入参与SQL参数的快速映射。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

基于规范在线发布后的API同样也会部署到Node-Red中形成流程,支持对发布后API的动态编排,公有私有配置、API端点的在线测试。

基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)基于对象模型和数据驱动的API低代码开发平台(基于对象的编程)

简单总结

经过上面典型场景描述可以看到,API低代码开发平台围绕对象驱动和元数据建模为核心,支撑API接口的快速定义,快速发布能力。同时在已有数据库表和对象的情况下又能够快速的将数据库表,参数化SQL预计等发布为API接口服务。

平台API开发设计功能支持Mysql/Oracle/Sqlserver三种类型数据库,并且API加入了数据库事务支持,针对API服务的整体性事务,出错回滚所有数据。在线API的调用和导出后微服务应用中API的调用数据和返回数据完全相同,保证了API在线使用和分布式部署后使用的一致性。在线API调用日志都已记录并可供查询和统计。

同时在平台我们当前还在进一步完善对于发布的API接口进行服务编排和能力组装的能力。该平台一方面是应用到日常的API接口快速开发,同时也是低代码开发平台的一个重要能力补充。

注:欢迎点赞,欢迎转发评论,如果大家都感兴趣的话我后续会考虑将该产品开源出来。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年7月8日 下午1:49
下一篇 2024年7月8日 下午2:01

相关推荐