- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
作者:京东科技 常姜洲 。
近期参加公司组织的极客中餐厅训练营,我们所在的小组接到的课题是微服务的低代码平台架构设计。目标是:结合京东业务研发实际情况,针对后端研发人员,设计一个微服务低代码平台,助力更高效低交付业务需求。现已结业,将我在本次项目中沉淀设计出的设计文档整理成文,期待与大家有进一步的碰撞沟通 。
平台为开发者的三个阶段提供的核心功能:
开发阶段:服务编排能力, 提供可组合的方式绑定事件源和事件消费者(函数、API、数据源管理等基础能力) 。
部署阶段:生成、托管、 获取、构建和打包代码.
运维阶段:为 Serverless 应用提供部署和服务支持。提供友好的日志系统,能够帮助平台工具使用者快速定位问题,提供对各种使用中间件状态监控,避免工具平台成为一个黑盒子 。
整个3阶段如下图所示:
角色与主功能说明:
本低代码开发平台的服务对象为开发者,旨在使用低代码开发平台,进行快速的微服务应用开发与部署,相对于传统的开发与部署方式减少研发时间,降低成本 。
Low Code 开发面板:
提供整个低代码应用开发生命周期的全功能的运营后台面板,可以在此面板完成开发阶段的各项配置、流程编排、脚本编写与调试、部署等功能.
Low Code 控制面板:
提供各种服务治理,告警配置管理,配置管理等服务控制功能模块 。
基础功能说明:
• 提供触发器、脚本函数、可视化函数的、连接器的开发与管理 。
• 提供多环境配置文件隔离 。
• 提供应用维度、函数维度监控相关配置 。
• 提供应用工程所有源文件、各环境配置数据的的版本管理 。
部署功能说明:
提供在线构建应用工程,在线调试函数、触发器、连接器等功能,调试完毕后可一键进行发布 。
特色功能:
为进一步提升业务域功能复用度,进一步减少重复功能开发的成本,同样提供基于模板,函数扩展点等功能的快速复用湖开发 。
依赖:
• 方便与JSF体系内的服务更好的融合,接入JSF注册中心API,进行JSF注册服务的信息获取 。
• 与统一配置平台打通进行在线配置变更的存储与变更,平台基础配置的存储与变更 。
• 存储层,元数据使用关系型数据库存储,流程文件、资源文件使用对象存储,源代码等文件使用git管理或者对象存储 。
• 监控功能依赖贡献现有的监控平台 UMP 、SGM的 的OPEN API 实现 。
• 日志平台,公司的日志平台暂无OPEN API 可以共建、或者私有化部署一套实现 。
开发与测试、构建保存、发布、运行 。
用户在编辑器中完成触发器、连接器、函数等主要低代码构件,可能复用已有模板和业务域能力进一步为开发提速 。
开发完成后可以根据属性配置、语言环境构建打包函数镜像,同时生成版本号.
发布版本,完成部署.
应用实例在运行时提供服务 。
• 可视化创建连接器 。
• 可视化创建触发器 。
• 支持可视化创建函数流程,BPMN, 流程节点可以是函数实体或者连接器实体,流程关系支持表达式编辑 。
• 支持脚本编写创建函数,支持多语言:Groovy,Java 。
• 支持多环境配置信息配置 。
• 支持配置通用函数、触发器、连接器等监控,健康度指标收集配置 。
蓝色部分是我们平台重点建设的应用 。
流量入口主要分为京东内外部两种流量入口 。
对于HTTP接口上层可以对接成熟的网关转换为对低代码应用的JSF调用即可,此部分本身已经实现 0代码,无需重复建设 。
对于JSF接口可以使用低代码应用的JSF接口触发器调用 。
监控与告警主要还是以复用公司内部组件为主,基于OPEN API 封装 。
下层主要依赖其他业务部门提供的JSF接口、各大中间件、存储层以及外部的一些HTTP接口、特殊协议的接口,消息等 。
每个低代码平台的应用都有一个代理服务(LC proxy)负责和平台通信,指令下发,数据上报等 。
低代码应用不改变现有应用的通信方式和现有的JSF接口、数据库、缓存等中间件使用原有方式通信 。
控制中心:负责给 proxy 发控制指令,配置指令、服务治理指令等 。
数据收集中心:负责收集低代码运行时配置的健康度指标源数据、流量等其他运行数据收集 。
低代码平台单机应用为1个JVM 进程,和监控agent 、日志 agent 等agent进程一同部署在容器、或者KVM、物理机等OS 环境中 。
平台应用本身核心 。
low code proxy ,提供平台api接口,接受平台的指令,如:发布指令,接受到发布指令后去相关的存储服务拉取元配置信息和函数脚本、触发器、连接器配置、配置文件等低代码应用的源文件 。
执行引擎,负责对低代码应用连接器的加载、函数加载、触发器配加载,加载完成后对外提供服务,等待各种触发器的流量触发、 。
低代码应用核心构件 。
触发器为应用的流量入口:如接口、MQ消费者,定时任务回调等等,平台支持自定义触发器开发 。
函数为业务逻辑的编排,可以是特定语言的函数脚本,可以是bpmn组合的流程文件, 。
连接器负责和下游RPC接口,存储数据源、中间件平台的消息通信 。
多环境配置信息提供不同环境的参数配置 。
以上几个核心构件的有机组合共同在应用层基础能力至之上提供了 。
低代码应用作为一个运行单元被发布到平台应用中 。
由于是小组共创设计,我在详细设计中主要负责了连接器与触发器的设计部分,其他如函数、配置部分的设计与此详细设计这里不再赘述。大概思路如下 。
函数:支持各种语言的表达式函数、支持BPMN可视化流程编排 。
多环境配置:需要支持测试、生产、预发等环境配置文件 。
日志: 支持平台开发者自定义日志是否打印,打印格式,是否有掩码等 。
在一个低代码应用中连接器主要负责和其他业务方提供的RPC服务、中间件、存储等实体进行通信的组件 。
可以在脚本函数中直接调用连接器,也可以在流程函数中直接调用连接器 。
连接器支持其他未知新协议的制定 。
1、为了适应内外部不同的连接器诉求,平台提供自定义触发器的能力 。
2、预留使用连接器使用的配置信息,为引入的通信中间件预留未来使用该触发器的使用方需要0代码配置的配置信息,如数据库的地址,账号密码等信息 。
3、连接器需要实现平台提供的API,这样以便函数或者触发器可以直接调用该连接器 。
4、调试无误后保存触发器,提交平台审核,审核通过后平台可上架该触发器 。
1、为了适应内外部不同的触发器诉求,平台提供自定义触发器的能力 。
2、预留使用触发器使用的配置信息,为引入的通信中间件预留未来使用该触发器的使用方需要0代码配置的配置信息,如JSF的接口地址,别名等 。
3、使用纯代码写出该触发器的源代码,并预留调用低代码函数的入口,以便将来使用该触发器的使用者可以0代码配置触发器所调用的函数 。
4、调试无误后保存触发器,提交平台审核,审核通过后平台可上架该触发器 。
a、元信息,0代码,包含低代码应用的0代码开发部分的触发器元信息、连接器元信息 。
1、触发器配置信息:
▪ 通信中间件所需要的各个参数,接口名等等 。
▪ 调用函数的函数名称 。
▪ 是否打印日志,日志是否脱敏 。
2、连接器配置信息 。
▪ 通信中间件所需要的各个参数,密码,用户名等等 。
▪ 是否打印日志,日志是否脱敏 。
b、源文件,0代码,包含:流程文件、脚本文件 。
◦ 可视化流程编排产生的源文件,如bpmn流程文件 。
◦ 脚本编码产生的脚本文件,如自定义java函数 。
c、多环境配置,0代码,包含各个环境的配置文件 。
◦ 开发环境、生成环境的各个配置信息等,配置信息可以在触发器、函数、连接器中使用引入使用 。
d、日志组件配置 。
◦ 日志打印输出格式 。
◦ 日志输出路径 。
◦ 全局脱敏字段,脱敏正则 。
e、监控组件配置 。
◦ 监控埋点打印路径 。
◦ 监控埋点打印格式 。
d、低代码平台应用底座:
执行引擎、LC Proxy、中间件依赖的jar、应用框架springboot的jar等,这部分跟随不同的构建部署方式为可选项 。
1、源文件热部署 。
这种方式应对于低代码平台的租户使用低代码平台所有集群的共享资源,选取一部分可用资源以后在控制面板进行选择发布,可以使用指定ip的模式应对相关权限问题,也可以不指定ip使用平台自定义分配.
▪ 受平台资源调度管控,参考上周控制面板的功能 。
▪ 日志与监控埋点由 LC Proxy 采集到平台提供的日志平台和监控平台 。
2、构建jar包、war包 。
这种方式应对于有自己的主机用户,拿到成品后即可部署无状态应用,打的包中不包含LC Proxy部分,执行引擎在应用启动的时候自动加载包中特定路径的流程文件、脚本文件等.
▪ 日志打印到特定目录,供用户自己的日志采集器采集 。
▪ 埋点文件按照特定格式打印到特定目录,供自己的日志采集器采集 。
3、构建镜像 。
这种方式应对于有自己的容器用户,拿到成品后即可部署无状态应用,打的包中不包含LC Proxy部分,执行引擎在应用启动的时候自动加载包中特定路径的流程文件、脚本文件等.
▪ 日志打印到特定目录,供用户自己的日志采集器采集 。
▪ 埋点文件按照特定格式打印到特定目录,供自己的日志采集器采集 。
4、低代码平台和部署平台的关系 。
◦ 内部 。
▪ 内部部署的低代码平台为了方便各业务方灵活使用,平台提供两种能力 。
▪ 1、共享资源模式:平台租户共享平台资源池,适用于消耗资源不大并发量不高的应用, 使用低代码平台本身提供的日志平台、监控平台结合做到各个维度的立体监控 。
▪ 2、自定义资源模式:平台对接体系内的JDOS平台,可以将低代码应用与JDOS应用进行关联,使用在JDOS平台申请的应用进行部署。这种方式提供单独的镜像文件进行部署,可结合体系内的日志中间件、监控平台, 与低代码平台本身提供的日志平台、监控平台结合做到各个维度的立体监控 。
◦ 外部 。
▪ 外部需求为成品包的时候,只需要构建出 如上所述的 jar、war供其下载即可 。
▪ 外部需求为低代码平台私有化部署的时候,需要将方案设计中的几大应用为用户做私有化部署 。
1、扩展性不仅仅是在某一项功能上的扩展,站在全局视角看在架构设计中所有产品功能理论上都要尽可能考虑模块化,可插拔,进而搭积木成平台化,真正做到全场景和全链路可扩展 。
2、团队小伙伴对HTTP 触发器的设计输出,让我联想到 JSF注册中心等通用类注册中心都要解决的高可用问题,举一反三,同场景的同类解决方案的核心问题是相通的 。
3、对于未来业务发展生命周期没那么长,数据要求没有强隔离诉求的场景,能否基于数据模型做一层数据层的0代码开发?
4、流程驱动的低代码可以和数据驱动的低代码很好地结合起来 。
5、低代码平台产出物的多样化,为之后交付项目的产出物打开了思路,很多时候要站在客户角度考虑,客户的应用场景是什么,需要什么,那么我们就提供什么,张宇轩单元可跑,也可圈定某一部分功能集合,打包输出 。
低代码平台适合的场景的一些思考 。
1、可以应用在上层营销系统的开发中 。
2、可以用在流程较为通用的场景如:消息转化、数据统计、接口转发 。
3、可以应用在已有成熟的业务线进行外围的业务开发,如支付、结算等稳定系统上层要做一些简单业务编排的场景用 。
4、 面对同样一个业务需求是使用低代码开发还是使用纯代码开发,没有明确的可量化的分水岭,但是建议尝试,从中获到提效之后下一次面临需求的时候就会有较为明确的答案 。
案例1:我们曾在一个上层营销活动系统重尝试基于表达式引擎做了一个半配置化的活动配置系统(那个时候还没听过低代码这个词),现在想来算是比较原始的支持低代码系统,上新一个活动原本需要3个人日的开发量,基于对以往流程的复用,使用脚本语言,使用表达式进行编排和发布,0.5人日就搞定了,且系统无需重新发布。不得不说在合适的场景,低代码还是非常有空的.
案例2:大促的时的业务数据大屏的制作相信很多人都经历过,我们最近两次大促采取的方案都是使用星链对已有的数据接口和新的数据指标进行简单编排加工,提供JSF服务,再结合我们内部的网关系统将接口协议转化为HTTP, 直接在展示平台(如莫奈大屏)上直接使用,大促过后资源也可随之释放,非常方便与高效,同时也降低了研发成本 。
参加训练营后还是有一些感触想分享给大家 。
1、感谢马老师的指导和各位评委老师的指点,感恩大家的信任,感谢同组的大佬们,从大家身上学习到不同的思路。每个人来此不同团队,通过和大家的讨论,发掘了很多新的看待产品与架构的视角 。
2、流程驱动的低代码平台可以和数据驱动的低代码以及部分0代码开发组件可以很好地有机整合成统一的低代码平台,进一步提升研发效率 。
3、整体感觉训练营节奏紧凑,干货满满,架构设计方面对平台扩展性的思考充分得到训练 。
最后此篇关于一种面向后端的微服务低代码平台架构设计的文章就讲到这里了,如果你想了解更多关于一种面向后端的微服务低代码平台架构设计的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我的 Linux Centos Apache 服务器的性能有问题。我有一个程序(用 c 语言编写)可以同时执行许多 http 请求。这个过程本身看起来非常有效,就好像我可以同时向外部服务器发出 500
我想知道如何将并行端口上的数据引脚设置为高电平和低电平。我相信我可以使用 PyParallel 来实现此目的,但我不确定如何设置特定的引脚。 谢谢! 最佳答案 您在这里谈论的是软件-硬件接口(inte
让我有一个像这样的日期时间索引的数据框: date_time open high low close vol 2018-05-13 18:00:00 70.
在 emacs Octave 模式下,当我输入 M-x run-octave 时,命令会卡住,所以我使用 C-g 进行转义。我可以用 C-x b 切换到 *Inferior Octave* 缓冲区,但
我正在 sklearn 中运行 gridsearchCV,尝试使用此代码找到最佳模型参数。 modelDNN= KerasRegressor(build_fn=build_DNN_model, epo
美好的一天。我想知道 android 存储是否低,它会影响应用程序性能吗?因为同一个应用程序在另一台设备上运行速度很快,而同样的应用程序在另一台设备上非常滞后,后者有 12GB 内存中的 2GB 可用
所以我在列卡上有一个带有索引的表 当我运行时 SELECT COUNT(DISTINCT(card)) FROM table 它返回 490 个不同的条目 但是当我运行的时候 SHOW INDEXES
我正在使用手动方法将二进制转换为十进制。此代码在最后一位为高的情况下工作正常,例如:1001。当最后一位为零 [低] 时会出现错误。例如:1010 应该给出 10 但给出 5,因为没有考虑最后一位。有
我一直在努力优化我的站点和数据库,并且我一直在使用 mysqltuner.pl 来帮助解决这个问题。除了表缓存命中率,无论我在 my.cnf 中将它提高多高,我几乎都得到了正确的结果,我仍然命中大约
深入研究 sprite kit (xcode 5)。我正在使用两个示例程序,1. 创建新项目时包含的默认宇宙飞船示例和 2. 我下载的 Adventure Game。 在 iOS 模拟器中运行这些示例
编辑: 感谢大家在这里提供答案,项目已完成。 https://github.com/0xyg3n/ProcessDaemon/ 如果有人想出可能会更好的多线程解决方案,我想。 我是 C# 的新手,我想
我有一个交换 Word 变量的字节(低/高)的过程(它与 System.Swap 函数执行相同的操作)。该过程在编译器优化关闭时有效,但在编译器优化打开时无效。有人可以帮我解决这个问题吗? proce
我以前听说过这些术语描述语言,例如 C 并不是一种低级语言,C++是中级语言,而Python是一种高级语言。我知道它必须与代码的编译方式以及代码的编写方式有关。但是我想知道的是,什么将语言定义为这三类
我有一个关于 NoSQL 类型数据库的问题,特别是 MongoDB,但它通常适用于大多数键值或基于文档的存储。 NoSQL 的一些卖点是速度和可扩展性,但在我看来,与关系数据库相比,开销很大。 你有很
如果没有此代码,fps 为 60-65。但是当我使用这段代码时,fps 下降到 50。 另一个问题是某些设备上的 FPS 太低。然而,游戏非常简单。我对所有形状使用 ShapeRenderer。游戏在
您好,我的名字是 Ryan,我目前正在开发自己的 2D java 游戏。目前游戏世界中有很多物体。游戏重新开始时,世界会加载 100 棵随机放置的树木,这些树木是使用数组列表和树类制作的。我的游戏使用
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我刚刚将我的 Heroku postgres 数据库从 Kappa 计划(800MB RAM,postgres 9.1)升级到 Ronin 计划(1.7GB RAM,postgres 9.2),但性能
现在我正在使用我的 NSDictionary 并运行所有值的循环以找到低值、高值和计算平均值。 由于我是IOS 的新手,所以我想问问是否有更好的方法来做到这一点。有没有? 谢谢。 最佳答案 这个问题的
我目前正在使用 genuino 101 进行一个项目,我需要通过 i2c 读取大量数据,以填充任意大小的缓冲区。从下图中我可以看到读取请求本身只需要大约 3毫秒,写请求大约 200 纳秒。 但是在同一
我是一名优秀的程序员,十分优秀!