CN109445937B - 一种组件化编程及无缝执行方法 - Google Patents

一种组件化编程及无缝执行方法 Download PDF

Info

Publication number
CN109445937B
CN109445937B CN201811209440.2A CN201811209440A CN109445937B CN 109445937 B CN109445937 B CN 109445937B CN 201811209440 A CN201811209440 A CN 201811209440A CN 109445937 B CN109445937 B CN 109445937B
Authority
CN
China
Prior art keywords
transaction
function module
code
information
transaction function
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201811209440.2A
Other languages
English (en)
Other versions
CN109445937A (zh
Inventor
赵瑞彬
崔晓光
袁亚杰
潘旭营
曹磊
郭海英
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shandong Etone Development Group Co ltd
Original Assignee
Shandong Etone Development Group Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shandong Etone Development Group Co ltd filed Critical Shandong Etone Development Group Co ltd
Priority to CN201811209440.2A priority Critical patent/CN109445937B/zh
Publication of CN109445937A publication Critical patent/CN109445937A/zh
Application granted granted Critical
Publication of CN109445937B publication Critical patent/CN109445937B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/5011Pool

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)
  • Stored Programmes (AREA)

Abstract

本发明提供一种组件化编程及无缝执行方法,配置中心将***交易功能模块配置到***节点,配置中心将配置信息推送至分布式缓存服务器,各***节点每经过一预设时长从分布式缓存服务器抓取配置信息,并将配置信息更新至本地进程缓存;***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块;若在本地进程缓存中查找到与提取特征值相符合的***交易功能模块,则执行所述***交易功能模块,实现交易数据处理。解决发布或回退时需重启服务造成服务丢失使交易不可用的问题;不需要回退***,或重启***。本发明将灰度发布升级为精确发布,使应用发布完全可控。

Description

一种组件化编程及无缝执行方法
技术领域
本发明涉及数据处理领域,尤其涉及一种组件化编程及无缝执行方法。
背景技术
在实时高并发的实时交易***或软件体系中,为了支撑业务功能的快速迭代,实现快速无影响发布,降低***性风险及资金损失,增强***鲁棒性,通常采用如下方式:
A)在中间件层:使用nginx或类nginx的openresty、Tengine等负载均衡/反向代理软件或F5等负载均衡设备,基于权重、ip、hash等规则进行业务***流量的不均匀分发,实现灰度发布;使用redis、memcache、encache等分布式缓存***存储基于请求特征的分发规则,及规则结果对应的***,依赖提取出的请求报文特征,进行交易***的节点的指定分发;在服务器节点基于请求报文特征进行内部处理函数的选取。
B)在应用***进程内部,通常采用如下方式:采用AOP或IOC模式,或函数指针模式,依赖约定或配置驱动进行互相内部调用;采用脚本语言等解释性语言,封装底层组件库,依赖于具体前置后继条件,控制流程并调用底层组件进行执行。
C)在应用***外部,通常采用如下方式:基于consul、dubbo等软件搭建配置中心,基于zookeeper等调度软件实现跨服务调用;基于微服务模式实现应用解耦,采用大量的小进程剥离服务,通过独立起停进程控制软件服务快速发布;通过客户端软件往服务器下载对应的版本程序,在客户端本地执行。
基于上述指出的行业方案,存在如下缺点:基于请求特征进行流量分发,采用灰度发布,发布应用相对应的***节点命中的交易依然存在风险,尤其对于金融交易等高并发且资金敏感***来说,依赖于约定或者配置,在发布时需要更新散落于操作***或镜像资源的代码配置文件,并重启应用进程进行加载,在启动过程中交易存在服务丢失的风险,而且无法进行在交易过程中进行特征数据的匹配和执行。
编译性语言或解释性语言的拦截调用方式及加载效率较差,在高并发场景下处理能力容易达到瓶颈。
微服务模式,在复杂***将会占用大量的进程资源,且存在不同服务模块之间扇入扇出流量背压的问题;一旦发布有误,必须回退版本,不能实现细化到具体用户具体交易具体组件的细粒度准确控制。
发明内容
为了克服上述现有技术中的不足,本发明提供一种组件化编程及无缝执行方法,方法包括:
步骤一:在配置中心配置***交易功能模块;
步骤二:配置中心将***交易功能模块配置到***节点,使***节点基于用户请求要素动态规则得出请求特征值或具有静态要素标记的请求特征值;
步骤三:配置中心将配置信息推送至分布式缓存服务器,同时各***节点每经过一预设时长从分布式缓存服务器抓取配置信息,并将配置信息更新至本地进程缓存;
步骤四:***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块;
若在本地进程缓存中查找到与提取特征值相符合的***交易功能模块,则执行所述***交易功能模块,实现交易数据处理。
优选地,步骤四之后还包括:
若在本地进程缓存中未查找到与提取特征值相符合的***交易功能模块;
***节点从分布式缓存服务器中查找与提取特征值相符合的***交易功能模块;
若在分布式缓存服务器中查找到与提取特征值相符合的***交易功能模块,则将所述***交易功能模块配置到本地进程缓存中;
在本地进程缓存执行所述***交易功能模块,实现交易数据处理。
优选地,步骤四之后还包括:
若在分布式缓存服务器中未查找到与提取特征值相符合的***交易功能模块,切换查找用户交易请求指令的数据源,提取用户交易请求指令中的应用代码,在配置中心的数据库配送表中基于用户交易请求指令中的应用代码查找***交易功能模块;
若在配置中心的数据库配送表中查找到与应用代码相匹配的***交易功能模块,则将所述***交易功能模块配置到分布式缓存服务器中;
再将所述***交易功能模块配置到本地进程缓存中;
在本地进程缓存执行所述***交易功能模块,实现交易数据处理。
优选地,步骤一还包括:创建消息总线,消息总线用于获取***交易功能模块的功能,***交易功能模块的执行交易流程及交易顺序,还为配置中心与***节点之间以及***节点之间提供通信服务;
消息总线将获取的***交易功能模块的执行交易流程及交易顺序配置到配置中心以及各个***节点;
消息总线包括:消息配置队列、事件监听线程池、监听进程、工作线程池,进程内存;
消息配置队列用于配置***交易功能模块的发起地址,配置***交易功能模块的功能,配置***交易功能模块的接收地址,配置***交易功能模块的执行交易流程及交易顺序,配置***交易功能模块的时间;
配置***交易功能模块的功能包括:预设数量的代码逻辑片段和预设数量的代码组件;
每个交易数据处理流程由若干代码逻辑片段组成,每一逻辑片段由若干个代码组件组成,上一逻辑片段的最后一代码组件输出指定下一逻辑片段的起始代码组件;
***交易功能模块的执行交易流程,依据交易顺序,将交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系,逻辑片段之间的跳转逻辑进行图形化的配置;将***交易功能模块的执行交易流程写入数据库进行保存。
优选地,步骤二还包括:
启动***节点,将存储后的***交易功能模块的执行交易流程配置加载至各个***节点的本地进程缓存中,还将***交易功能模块的执行交易流程存储至***节点的本地存储器;
***节点通过守护线程进行缓存的即时刷新或接收配置中心发布的广播消息,以进行***交易功能模块的执行交易流程代码及时更新。
优选地,步骤二还包括:配置中心设置有组件库,预设的代码组件存储在组件库;
配置中心在组件库中对每个代码组件进声明;声明信息包括:代码组件地址,代码组件主类,代码组件的源代码,编译的可执行程序名称及发布路径;发布路径包括:代码对应发布的服务器路径地址;
***节点通过守护线程轮询配置中心的组件库,判断组件库中的代码组件是否更新;
当组件库中的代码组件更新时,判断更新的代码组件是否与***节点的***交易功能模块的每个代码逻辑片段中的代码组件相符合;
如符合,***节点通过与配置中心之间配置的代码组件更新发布路径,下载更新的代码组件,将下载的更新代码组件保存至***节点的本地存储器;
***节点将更新的代码组件加载到相应的***交易功能模块的代码逻辑片段中,形成更新后的***交易功能模块;同时保存未更新代码组件的***交易功能模块;
***节点将更新代码组件的信息形成更新日志,并在更新日志上标识***节点的编码信息,将具有***节点编码信息的更新日志上传至配置中心;
配置中心更新***日志,通过***日志记录各个***节点的更新状态信息。
优选地,***节点的应用进程通过守护线程监控本地资源及***交易流程的配置信息;
加载本地代码组件信息,辨识本地***交易功能模块的代码组件更新信息;当当前交易信息为更新代码组件的交易流程时,调用更新后的***交易功能模块执行交易流程;
当当前交易信息为未更新代码组件的交易流程时,调用未更新的***交易功能模块执行交易流程;
***节点的代码组件更新后,进行交易流程配置的更新执行,保证***准确性。
优选地,步骤二之后还包括:启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;
在进行交易处理时,依据***交易功能模块的执行交易流程及交易顺序,执行交易的***节点向消息总线的事件监听线程池发送消息;
消息总线接收到***节点发送的交易事件后,监听进程将交易事件的***节点地址,交易双方信息及状态信息进行登记,并存储在进程内存中;
监听进程将交易事件的每个步骤分发给工作线程池,工作线程池接收交易事件,工作线程池对交易事件过程,依据预设的交易顺序,对交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系逐一进行监控校验,直至交易处理完成。
优选地,方法还包括:启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;
启动预设交易处理进程,各个***节点依据***交易功能模块的执行交易流程及交易顺序,执行交易,并向消息总线的事件监听线程池发送消息;
消息总线接收到***节点发送的交易事件后,监听进程将交易事件的***节点地址,交易双方信息及状态信息进行登记,并存储在进程内存中;
监听进程将交易事件的每个步骤分发给工作线程池,工作线程池接收交易事件,工作线程池对交易事件过程,依据预设的交易顺序,对交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系逐一进行监控校验;
在执行预设过程中,监测到当某一交易步骤的顺序变更,或某一代码组件变更,或代码组件之间的引用关系发生变更时,监听进程回调执行过程,在分布式缓存服务器中获取***交易功能模块是否更新;
如在分布式缓存服务器中***交易功能模块已更新时,执行更新后的***交易功能模块,直至后续交易处理完成;
如在分布式缓存服务器中获取***交易功能模块未更新时,在配置中心和***节点中发出报错信息,并停止执行交易。
优选地,监听进程以观察序列模式,将交易过程中的正常执行信息、异常处理信息、预置信息及清理动作信息进行分别封装调用,将散落在代码组件内的各种应用流程异常信息、代码异常信息、底层异常信息,进行信息上浮显示报错,实现了错误信息的及时抛出,集中处理。
从以上技术方案可以看出,本发明具有以下优点:
本发明在交易过程中***节点基于用户请求要素动态规则得出请求特征值或具有静态要素标记的请求特征值,***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块若在本地进程缓存中查找到与提取特征值相符合的***交易功能模块,则执行所述***交易功能模块,实现交易数据处理。如不符合,则可以在分布式缓存服务器中查找,当然还可以在在配置中心的数据库配送表中查找,其中分布式缓存服务器和配置中心的数据库配送表可以在交易过程中,或***执行时,或调试时进行更新。解决发布或回退时需重启服务造成服务丢失使交易不可用的问题;不需要回退***,或重启***。本发明将灰度发布升级为精确发布,使应用发布完全可控。
解决业界通用的应用进程内代码组件配置化调用方法效率差、异常处理散乱的问题。
交易流程动态发布:依据引用关系的组合配置,动态发布不同的应用处理流程;依据动态或静态的交易特征值发布匹配流程版本的应用流程信息,依据缓存机制提高匹配效率,在交易时精确识别交易流程。
将匹配到的交易流程版本对应的应用代码进一步细分,通过配置化使应用代码中的构成代码单元即代码组件可动态发布。
解决了传统代码发布必须重启应用***进程,造成服务丢失;避免了传统代码发布必须基于大的交易流程进行断代式升级,无法在单一应用进程中兼容同一交易流程的不同版本,使其并行,满足动态发布或回退的需要。
交易流程细分配置,使交易流程的发布细分到代码组件级别,即函数层级,组件实现版本化配置及发布,并将代码组件的调用关系进行版本化配置,使交易流程内部模块及调用的逻辑关系可进行动态配置。
配置中心依据构成的指定版本的功能配置的代码细分配置信息,动态编译源码并发布至资源服务器,应用节点动态获取代码资源并在进程内可隔离执行统一代码组件的多种版本,达到业务流程的局部模块动态切换能力。
附图说明
为了更清楚地说明本发明的技术方案,下面将对描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为组件化编程及无缝执行方法流程图;
图2为组件化编程及无缝执行方法实施例流程图;
图3为组件化编程及无缝执行方法实施例流程图。
具体实施方式
本发明提供一种组件化编程及无缝执行方法,如图1所示,方法包括:
S1:在配置中心配置***交易功能模块;
***交易功能模块是基于交易需要的交易方式,或交易程序,或为执行交易过程所需要的计算机序列。
S2:配置中心将***交易功能模块配置到***节点,使***节点基于用户请求要素动态规则得出请求特征值或具有静态要素标记的请求特征值;
可以理解的是用户请求要素动态规则是在***中预设的一个交易规则,此交易规则具有一定的执行代码,程序等等。为了提高交易过程的安全性,在交易规则程序中配置了关键词,关键字等等相关的内容。这样用户与***之间具有相同的交易规则,来进行交易。在交易过程中为了相互验证需要***对用户的要素动态规则进行验证,验证是否满足用户与***之间预先设定的交易规则。当然用户端也验证***所具有的交易规则是否满足预设交易规则。为了提高验证效率,降低验证程序,可以在交易规则上设置特征值或具有静态要素标记的请求特征值,这样只要用户端和***端相互验证设置特征值或具有静态要素标记的请求特征值即可。
S3:配置中心将配置信息推送至分布式缓存服务器,同时各***节点每经过一预设时长从分布式缓存服务器抓取配置信息,并将配置信息更新至本地进程缓存;
配置中心对更新后的配置信息推送至分布式缓存服务器,各个***节点在分布式缓存服务器进行抓取并配置到本地进程缓存。
为了提升交易的安全性,通常在经过一个预设时长会对交易过程中的关键字,或关键词,或为了验证设置特征值,或具有静态要素标记的请求特征值进行更新升级,避免被非法破解而影响交易的安全性。
S4:***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块;
S5若在本地进程缓存中查找到与提取特征值相符合的***交易功能模块,则执行所述***交易功能模块,实现交易数据处理。
本发明中,动态发布:指非经应用重启,即可替换正在运行的程序版本。
灰度发布:指针对部分用户进行新功能发布,逐步扩大***功能影响范围。
代码组件:指组成某个具体功能的函数模块,其实现了对数据操作及操作方法的最小封装的功能单元。
配置中心对每个***节点在消息总线上注册访问地址及操作方式,配置中心将***信息处理模块配置到每个***节点,实现每个***节点基于***信息处理模块执行交易流程。
其中,配置中心对每个***节点的操作方式包括对每个***节点3的增删改查,或对每个***节点进行数学计算或逻辑运算等功能。
为使得本发明的发明目的、特征、优点能够更加的明显和易懂,下面将运用具体的实施例及附图,对本发明保护的技术方案进行清楚、完整地描述,显然,下面所描述的实施例仅仅是本发明一部分实施例,而非全部的实施例。基于本专利中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其它实施例,都属于本专利保护的范围。
本发明还提供一实施例,如图2所示,
S11:在配置中心配置***交易功能模块;
S12:配置中心将***交易功能模块配置到***节点,使***节点基于用户请求要素动态规则得出请求特征值或具有静态要素标记的请求特征值;
S13:配置中心将配置信息推送至分布式缓存服务器,同时各***节点每经过一预设时长从分布式缓存服务器抓取配置信息,并将配置信息更新至本地进程缓存;
S14:***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块;
S15:若在本地进程缓存中未查找到与提取特征值相符合的***交易功能模块;
***节点从分布式缓存服务器中查找与提取特征值相符合的***交易功能模块;
S16:若在分布式缓存服务器中查找到与提取特征值相符合的***交易功能模块,则将所述***交易功能模块配置到本地进程缓存中;
S17:在本地进程缓存执行所述***交易功能模块,实现交易数据处理。
如果***节点未做到及时更新,或者在交易过程中***节点与用户端的提取特征值相符合,则在交易时,***节点自动从分布式缓存服务器中查找与提取特征值相符合的***交易功能模块。这里不再按照预设时长的规则获取更新状态。
本发明还提供一实施例,如图3所示,
S21:在配置中心配置***交易功能模块;
S22:配置中心将***交易功能模块配置到***节点,使***节点基于用户请求要素动态规则得出请求特征值或具有静态要素标记的请求特征值;
S23:配置中心将配置信息推送至分布式缓存服务器,同时各***节点每经过一预设时长从分布式缓存服务器抓取配置信息,并将配置信息更新至本地进程缓存;
S24:***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块;
S25:若在分布式缓存服务器中未查找到与提取特征值相符合的***交易功能模块,切换查找用户交易请求指令的数据源,提取用户交易请求指令中的应用代码,在配置中心的数据库配送表中基于用户交易请求指令中的应用代码查找***交易功能模块;
S26:若在配置中心的数据库配送表中查找到与应用代码相匹配的***交易功能模块,则将所述***交易功能模块配置到分布式缓存服务器中;
S27:再将所述***交易功能模块配置到本地进程缓存中;在本地进程缓存执行所述***交易功能模块,实现交易数据处理。
这里所描述的技术可以实现在硬件,软件,固件或它们的任何组合。所述的各种特征为模块,单元或组件可以一起实现在集成逻辑装置或分开作为离散的但可互操作的逻辑器件或其他硬件设备。在一些情况下,电子电路的各种特征可以被实现为一个或多个集成电路器件,诸如集成电路芯片或芯片组。
本发明还提供一实施例,步骤一还包括:创建消息总线,消息总线用于获取***交易功能模块的功能,***交易功能模块的执行交易流程及交易顺序,还为配置中心与***节点之间以及***节点之间提供通信服务;
消息总线将获取的***交易功能模块的执行交易流程及交易顺序配置到配置中心以及各个***节点;
消息总线包括:消息配置队列、事件监听线程池、监听进程、工作线程池,进程内存;
消息配置队列用于配置***交易功能模块的发起地址,配置***交易功能模块的功能,配置***交易功能模块的接收地址,配置***交易功能模块的执行交易流程及交易顺序,配置***交易功能模块的时间;
配置***交易功能模块的功能包括:预设数量的代码逻辑片段和预设数量的代码组件;
每个交易数据处理流程由若干代码逻辑片段组成,每一逻辑片段由若干个代码组件组成,上一逻辑片段的最后一代码组件输出指定下一逻辑片段的起始代码组件;
***交易功能模块的执行交易流程,依据交易顺序,将交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系,逻辑片段之间的跳转逻辑进行图形化的配置;将***交易功能模块的执行交易流程写入数据库进行保存。
配置中心是依据交易顺序,将交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系,逻辑片段之间的跳转逻辑进行图形化的配置,在图形化的配置中提取出请求特征值或具有静态要素标记的请求特征值;
用户方所拥有的是基于用户请求要素动态规则来得到的请求特征值或具有静态要素标记的请求特征值。用户方与配置中心之间基于请求特征值或具有静态要素标记的请求特征值的配置方式不同提高了交易的机密性及安全性。
本发明中,步骤二还包括:启动***节点,将存储后的***交易功能模块的执行交易流程配置加载至各个***节点的本地进程缓存中,还将***交易功能模块的执行交易流程存储至***节点的本地存储器;***节点通过守护线程进行缓存的即时刷新或接收配置中心发布的广播消息,以进行***交易功能模块的执行交易流程代码及时更新。
也就是处理上述在每经过一预设时长从分布式缓存服务器抓取配置信息以外,***节点通过守护线程进行缓存的即时刷新或接收配置中心发布的广播消息,以进行***交易功能模块的执行交易流程代码及时更新,保证更新的实时性,使得交易更为顺畅。
本发明传统代码发布必须重启应用***进程,造成服务丢失;传统代码发布必须基于大的交易流程进行断代式升级,无法在单一应用进程中兼容同一交易流程的不同版本,更无法兼容流程细分模块的不同版本,使其并行,满足动态发布或回退的需要。
交易流程细分配置,使交易流程的发布细分到代码组件级别(即函数层级),组件实现版本化配置及发布,并将代码组件的调用关系进行版本化配置,使交易流程内部模块及调用的逻辑关系可进行动态配置。
代码无缝切换,即配置中心依据构成的指定版本的功能配置的代码细分配置信息,动态编译源码并发布至资源服务器,应用节点动态获取代码资源并在进程内可隔离执行统一代码组件的不同版本,达到业务流程的局部模块动态切换能力。
如果在硬件中实现,本发明涉及一种装置,例如可以作为处理器或者集成电路装置,诸如集成电路芯片或芯片组。可替换地或附加地,如果软件或固件中实现,所述技术可实现至少部分地由计算机可读的数据存储介质,包括指令,当执行时,使处理器执行一个或更多的上述方法。例如,计算机可读的数据存储介质可以存储诸如由处理器执行的指令。
本发明中,步骤二还包括:配置中心设置有组件库,预设的代码组件存储在组件库;
配置中心在组件库中对每个代码组件进声明;声明信息包括:代码组件地址,代码组件主类,代码组件的源代码,编译的可执行程序名称及发布路径;发布路径包括:代码对应发布的服务器路径地址;
***节点通过守护线程轮询配置中心的组件库,判断组件库中的代码组件是否更新;
当组件库中的代码组件更新时,判断更新的代码组件是否与***节点的***交易功能模块的每个代码逻辑片段中的代码组件相符合;
如符合,***节点通过与配置中心之间配置的代码组件更新发布路径,下载更新的代码组件,将下载的更新代码组件保存至***节点的本地存储器;
***节点将更新的代码组件加载到相应的***交易功能模块的代码逻辑片段中,形成更新后的***交易功能模块;同时保存未更新代码组件的***交易功能模块;
***节点将更新代码组件的信息形成更新日志,并在更新日志上标识***节点的编码信息,将具有***节点编码信息的更新日志上传至配置中心;
配置中心更新***日志,通过***日志记录各个***节点的更新状态信息。
其中,***节点的应用进程通过守护线程监控本地资源及***交易流程的配置信息;
加载本地代码组件信息,进行进程内访问隔离,避免命名规范及加载冲突,辨识本地***交易功能模块的代码组件更新信息;当当前交易信息为更新代码组件的交易流程时,调用更新后的***交易功能模块执行交易流程;
当当前交易信息为未更新代码组件的交易流程时,调用未更新的***交易功能模块执行交易流程;
***节点的代码组件更新后,进行交易流程配置的更新执行,保证***准确性。
本发明中,步骤一:在配置中心配置***交易功能模块;步骤二之后还包括:启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;
在进行交易处理时,依据***交易功能模块的执行交易流程及交易顺序,执行交易的***节点向消息总线的事件监听线程池发送消息;
消息总线接收到***节点发送的交易事件后,监听进程将交易事件的***节点地址,交易双方信息及状态信息进行登记,并存储在进程内存中;
监听进程将交易事件的每个步骤分发给工作线程池,工作线程池接收交易事件,工作线程池对交易事件过程,依据预设的交易顺序,对交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系逐一进行监控校验,直至交易处理完成。
可能以许多方式来实现本发明的方法以及装置。例如,可通过软件、硬件、固件或者软件、硬件、固件的任何组合来实现本发明的方法以及装置。用于所述方法的步骤的上述顺序仅是为了进行说明,本发明的方法的步骤不限于以上具体描述的顺序,除非以其它方式特别说明。此外,在一些实施例中,还可将本发明实施为记录在记录介质中的程序,这些程序包括用于实现根据本发明的方法的机器可读指令。因而,本发明还覆盖存储用于执行根据本发明的方法的程序的记录介质。
本发明中,方法还包括:启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;
启动预设交易处理进程,各个***节点依据***交易功能模块的执行交易流程及交易顺序,执行交易,并向消息总线的事件监听线程池发送消息;
消息总线接收到***节点发送的交易事件后,监听进程将交易事件的***节点地址,交易双方信息及状态信息进行登记,并存储在进程内存中;
监听进程将交易事件的每个步骤分发给工作线程池,工作线程池接收交易事件,工作线程池对交易事件过程,依据预设的交易顺序,对交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系逐一进行监控校验;
在执行预设过程中,监测到当某一交易步骤的顺序变更,或某一代码组件变更,或代码组件之间的引用关系发生变更时,监听进程回调执行过程,在分布式缓存服务器中获取***交易功能模块是否更新;
如在分布式缓存服务器中***交易功能模块已更新时,执行更新后的***交易功能模块,直至后续交易处理完成;
如在分布式缓存服务器中获取***交易功能模块未更新时,在配置中心和***节点中发出报错信息,并停止执行交易。
也就是在执行步骤一在配置中心配置***交易功能模块之后,启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;启动预设交易处理进程对***各个节点进行测试,测试交易过程,并基于测试交易过程查找不足,并及时调整某一交易步骤的顺序,或调整某一代码组件,或调整代码组件之间的引用关系发生等等使本发明涉及的方法满***易要求和交易环节。
依据引用关系的组合配置,动态发布不同的应用处理流程;依据动态或静态的交易特征值发布匹配流程版本的应用流程信息,依据缓存机制提高匹配效率,在交易时精确识别交易流程。
上述执行预设过程可以在***执行过程中进行测试执行,也可以在每经过一预设时长来进行测试,还可以在***测试时进行等等。
本发明中,监听进程以观察序列模式,将交易过程中的正常执行信息、异常处理信息、预置信息及清理动作信息进行分别封装调用,将散落在代码组件内的各种应用流程异常信息、代码异常信息、底层异常信息,进行信息上浮显示报错,实现了错误信息的及时抛出,集中处理。
监听进程可以在本发明的步骤一至步骤四任一步骤进行监听。
观察序列模式指的是,在一个事件发生时的处理机制,将关联方划分为事件被观察对象及事件观察者,在事件(被观察对象)发生改变时,被观察对象通知观察者事件发生的改变,观察者监听被观察对象的改变并作出对应操作。
应用进程内组件调用机制:使用观察者序列模式,级联调用,可中断并上浮后集中处理各种异常信息,解决错误处理机制散乱的问题。
在一些实施例中,所述设备中的一个或多个设备的部分或所有功能或处理由计算机程序实现或支持,计算机程序由计算机可读程序代码形成并且被包括在计算机可读介质中。短语“计算机可读程序代码”包括任何类型的计算机代码,包括源代码、目标代码和可执行代码。短语“计算机可读介质”包括能够被计算机访问的任何类型的介质,诸如只读存储器(ROM)、随机存取存储器(RAM)、硬盘驱动器、光盘(CD)、数字视频盘(DVD)、或任何其他类型的存储器。
对所公开的实施例的上述说明,使本领域专业技术人员能够实现或使用本发明。对这些实施例的多种修改对本领域的专业技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本发明的精神或范围的情况下,在其它实施例中实现。因此,本发明将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。

Claims (9)

1.一种组件化编程及无缝执行方法,其特征在于,方法包括:
步骤一:在配置中心配置***交易功能模块;
创建消息总线,消息总线用于获取***交易功能模块的功能,***交易功能模块的执行交易流程及交易顺序,还为配置中心与***节点之间以及***节点之间提供通信服务;
消息总线将获取的***交易功能模块的执行交易流程及交易顺序配置到配置中心以及各个***节点;
消息总线包括:消息配置队列;
消息配置队列用于配置***交易功能模块的发起地址,配置***交易功能模块的功能,配置***交易功能模块的接收地址,配置***交易功能模块的执行交易流程及交易顺序,配置***交易功能模块的时间;
配置***交易功能模块的功能包括:预设数量的代码逻辑片段和预设数量的代码组件;
每个交易数据处理流程由若干代码逻辑片段组成,每一逻辑片段由若干个代码组件组成,上一逻辑片段的最后一代码组件输出指定下一逻辑片段的起始代码组件;
***交易功能模块的执行交易流程,依据交易顺序,将交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系,逻辑片段之间的跳转逻辑进行图形化的配置;将***交易功能模块的执行交易流程写入数据库进行保存;
步骤二:配置中心将***交易功能模块配置到***节点,使***节点基于用户请求要素动态规则得出请求特征值或具有静态要素标记的请求特征值;
步骤三:配置中心将配置信息推送至分布式缓存服务器,同时各***节点每经过一预设时长从分布式缓存服务器抓取配置信息,并将配置信息更新至本地进程缓存;
步骤四:***节点在收到用户交易请求指令后,对用户交易请求指令进行特征值提取,依据提取的特征值在本地进程缓存中查找与特征值相符合的***交易功能模块;
若在本地进程缓存中查找到与提取特征值相符合的***交易功能模块,则执行所述***交易功能模块,实现交易数据处理。
2.根据权利要求1所述的组件化编程及无缝执行方法,其特征在于,
步骤四之后还包括:
若在本地进程缓存中未查找到与提取特征值相符合的***交易功能模块;
***节点从分布式缓存服务器中查找与提取特征值相符合的***交易功能模块;
若在分布式缓存服务器中查找到与提取特征值相符合的***交易功能模块,则将所述***交易功能模块配置到本地进程缓存中;
在本地进程缓存执行所述***交易功能模块,实现交易数据处理。
3.根据权利要求2所述的组件化编程及无缝执行方法,其特征在于,
步骤四之后还包括:
若在分布式缓存服务器中未查找到与提取特征值相符合的***交易功能模块,切换查找用户交易请求指令的数据源,提取用户交易请求指令中的应用代码,在配置中心的数据库配送表中基于用户交易请求指令中的应用代码查找***交易功能模块;
若在配置中心的数据库配送表中查找到与应用代码相匹配的***交易功能模块,则将所述***交易功能模块配置到分布式缓存服务器中;
再将所述***交易功能模块配置到本地进程缓存中;
在本地进程缓存执行所述***交易功能模块,实现交易数据处理。
4.根据权利要求1所述的组件化编程及无缝执行方法,其特征在于,
步骤二还包括:
启动***节点,将存储后的***交易功能模块的执行交易流程配置加载至各个***节点的本地进程缓存中,还将***交易功能模块的执行交易流程存储至***节点的本地存储器;
***节点通过守护线程进行缓存的即时刷新或接收配置中心发布的广播消息,以进行***交易功能模块的执行交易流程代码及时更新。
5.根据权利要求1所述的组件化编程及无缝执行方法,其特征在于,
步骤二还包括:配置中心设置有组件库,预设的代码组件存储在组件库;
配置中心在组件库中对每个代码组件进声明;声明信息包括:代码组件地址,代码组件主类,代码组件的源代码,编译的可执行程序名称及发布路径;发布路径包括:代码对应发布的服务器路径地址;
***节点通过守护线程轮询配置中心的组件库,判断组件库中的代码组件是否更新;
当组件库中的代码组件更新时,判断更新的代码组件是否与***节点的***交易功能模块的每个代码逻辑片段中的代码组件相符合;
如符合,***节点通过与配置中心之间配置的代码组件更新发布路径,下载更新的代码组件,将下载的更新代码组件保存至***节点的本地存储器;
***节点将更新的代码组件加载到相应的***交易功能模块的代码逻辑片段中,形成更新后的***交易功能模块;同时保存未更新代码组件的***交易功能模块;
***节点将更新代码组件的信息形成更新日志,并在更新日志上标识***节点的编码信息,将具有***节点编码信息的更新日志上传至配置中心;
配置中心更新***日志,通过***日志记录各个***节点的更新状态信息。
6.根据权利要求5所述的组件化编程及无缝执行方法,其特征在于,
***节点的应用进程通过守护线程监控本地资源及***交易流程的配置信息;
加载本地代码组件信息,辨识本地***交易功能模块的代码组件更新信息;当当前交易信息为更新代码组件的交易流程时,调用更新后的***交易功能模块执行交易流程;
当当前交易信息为未更新代码组件的交易流程时,调用未更新的***交易功能模块执行交易流程;
***节点的代码组件更新后,进行交易流程配置的更新执行,保证***准确性。
7.根据权利要求1所述的组件化编程及无缝执行方法,其特征在于,
步骤二之后还包括:启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;
在进行交易处理时,依据***交易功能模块的执行交易流程及交易顺序,执行交易的***节点向消息总线的事件监听线程池发送消息;
消息总线接收到***节点发送的交易事件后,监听进程将交易事件的***节点地址,交易双方信息及状态信息进行登记,并存储在进程内存中;
监听进程将交易事件的每个步骤分发给工作线程池,工作线程池接收交易事件,工作线程池对交易事件过程,依据预设的交易顺序,对交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系逐一进行监控校验,直至交易处理完成。
8.根据权利要求1所述的组件化编程及无缝执行方法,其特征在于,
方法还包括:启动***服务,启动消息总线,各个***节点向消息总线注册***节点地址和***节点所对应的***交易功能模块所实现的交易功能;
启动预设交易处理进程,各个***节点依据***交易功能模块的执行交易流程及交易顺序,执行交易,并向消息总线的事件监听线程池发送消息;
消息总线接收到***节点发送的交易事件后,监听进程将交易事件的***节点地址,交易双方信息及状态信息进行登记,并存储在进程内存中;
监听进程将交易事件的每个步骤分发给工作线程池,工作线程池接收交易事件,工作线程池对交易事件过程,依据预设的交易顺序,对交易流程对应的若干逻辑片段,逻辑片段对应的代码组件的引用关系逐一进行监控校验;
在执行预设过程中,监测到当某一交易步骤的顺序变更,或某一代码组件变更,或代码组件之间的引用关系发生变更时,监听进程回调执行过程,在分布式缓存服务器中获取***交易功能模块是否更新;
如在分布式缓存服务器中***交易功能模块已更新时,执行更新后的***交易功能模块,直至后续交易处理完成;
如在分布式缓存服务器中获取***交易功能模块未更新时,在配置中心和***节点中发出报错信息,并停止执行交易。
9.根据权利要求1所述的组件化编程及无缝执行方法,其特征在于,
监听进程以观察序列模式,将交易过程中的正常执行信息、异常处理信息、预置信息及清理动作信息进行分别封装调用,将散落在代码组件内的各种应用流程异常信息、代码异常信息、底层异常信息,进行信息上浮显示报错,实现了错误信息的及时抛出,集中处理。
CN201811209440.2A 2018-10-17 2018-10-17 一种组件化编程及无缝执行方法 Active CN109445937B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811209440.2A CN109445937B (zh) 2018-10-17 2018-10-17 一种组件化编程及无缝执行方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811209440.2A CN109445937B (zh) 2018-10-17 2018-10-17 一种组件化编程及无缝执行方法

Publications (2)

Publication Number Publication Date
CN109445937A CN109445937A (zh) 2019-03-08
CN109445937B true CN109445937B (zh) 2021-01-01

Family

ID=65546948

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811209440.2A Active CN109445937B (zh) 2018-10-17 2018-10-17 一种组件化编程及无缝执行方法

Country Status (1)

Country Link
CN (1) CN109445937B (zh)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110738384B (zh) * 2019-04-17 2022-09-23 北京航天飞行控制中心 事件序列的校验方法及***
CN110190997A (zh) * 2019-05-31 2019-08-30 深圳前海微众银行股份有限公司 配置信息获取方法、装置、设备及计算机可读存储介质
CN111240910B (zh) * 2020-01-02 2024-04-05 北京航天测控技术有限公司 设备健康管理微服务生成方法、装置、设备及可读介质
CN112783926A (zh) * 2021-01-20 2021-05-11 银盛支付服务股份有限公司 一种减少调用服务耗时的方法
CN114118811A (zh) * 2021-11-29 2022-03-01 深圳壹账通智能科技有限公司 服务代码的生成、执行方法、装置、设备及存储介质

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102411506A (zh) * 2011-07-07 2012-04-11 杭州典能科技有限公司 Java***业务单元插件式管理***及业务功能动态变更方法
CN102541598A (zh) * 2011-12-26 2012-07-04 深圳联友科技有限公司 一种动态加载组件的方法及***
CN103297381A (zh) * 2012-02-22 2013-09-11 阿里巴巴集团控股有限公司 一种基于插件的业务访问方法及其***
CN104331827A (zh) * 2014-11-14 2015-02-04 中国建设银行股份有限公司 交易配置生成方法及交易匹配器
CN104516750A (zh) * 2013-09-29 2015-04-15 中国石油天然气股份有限公司 一种在scada***中实现插件集成与管理的方法及装置
CN105357059A (zh) * 2015-12-08 2016-02-24 中国建设银行股份有限公司 业务事件处理方法和装置
CN105491039A (zh) * 2015-11-27 2016-04-13 国网信息通信产业集团有限公司 一种分布式软件共享***

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8997047B2 (en) * 2012-12-13 2015-03-31 International Business Machines Corporation Dynamically updating code without requiring processes to restart

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102411506A (zh) * 2011-07-07 2012-04-11 杭州典能科技有限公司 Java***业务单元插件式管理***及业务功能动态变更方法
CN102541598A (zh) * 2011-12-26 2012-07-04 深圳联友科技有限公司 一种动态加载组件的方法及***
CN103297381A (zh) * 2012-02-22 2013-09-11 阿里巴巴集团控股有限公司 一种基于插件的业务访问方法及其***
CN104516750A (zh) * 2013-09-29 2015-04-15 中国石油天然气股份有限公司 一种在scada***中实现插件集成与管理的方法及装置
CN104331827A (zh) * 2014-11-14 2015-02-04 中国建设银行股份有限公司 交易配置生成方法及交易匹配器
CN105491039A (zh) * 2015-11-27 2016-04-13 国网信息通信产业集团有限公司 一种分布式软件共享***
CN105357059A (zh) * 2015-12-08 2016-02-24 中国建设银行股份有限公司 业务事件处理方法和装置

Also Published As

Publication number Publication date
CN109445937A (zh) 2019-03-08

Similar Documents

Publication Publication Date Title
CN109445937B (zh) 一种组件化编程及无缝执行方法
CN109408232B (zh) 一种基于交易流程的组件化总线调用执行***
US10656929B2 (en) Autonomously healing microservice-based applications
WO2020211222A1 (zh) 基于数据服务平台提供微服务的方法、装置、存储介质
US8812911B2 (en) Distributed testing of a software platform
US9253265B2 (en) Hot pluggable extensions for access management system
US9928059B1 (en) Automated deployment of a multi-version application in a network-based computing environment
US10360523B2 (en) System and method for executing business services and enhancing business performance through a business process modeling notation
CN109032825B (zh) 一种故障注入方法、装置及设备
US20110178946A1 (en) Systems and methods for redundancy using snapshots and check pointing in contact handling systems
CN110225078B (zh) 一种应用服务更新方法、***及终端设备
US10248679B2 (en) Collision detection using state management of configuration items
US11063811B2 (en) Multi-tenant event sourcing and audit logging in a cloud-based computing infrastructure
US20160026921A1 (en) Synchronization for Context-Aware Complex Event Processing
US10824548B1 (en) System and method for performance regression detection
US20210255917A1 (en) Structured Software Delivery And Operation Automation
US9596128B2 (en) Apparatus for processing one or more events
US20120036496A1 (en) Plug-in based high availability application management framework (amf)
CN112598529B (zh) 数据处理方法及装置、计算机可读存储介质、电子设备
CN115373757A (zh) 一种Promethues分片模式下集群监控数据缺失的解决方法和装置
CN113077241B (zh) 审批处理方法、装置、设备及存储介质
CN113469814A (zh) 交易时长数据的确定方法及装置
CN112612804A (zh) 一种服务治理参数更新方法及装置
CN113421109A (zh) 一种业务核对方法、装置、电子设备和存储介质
CN112783954A (zh) 数据访问方法、装置及服务器

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant