CN107220058A - 业务规则引擎的实现方法及系统 - Google Patents
业务规则引擎的实现方法及系统 Download PDFInfo
- Publication number
- CN107220058A CN107220058A CN201710414953.6A CN201710414953A CN107220058A CN 107220058 A CN107220058 A CN 107220058A CN 201710414953 A CN201710414953 A CN 201710414953A CN 107220058 A CN107220058 A CN 107220058A
- Authority
- CN
- China
- Prior art keywords
- business rule
- rule
- business
- condition
- new
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 78
- 230000009471 action Effects 0.000 claims abstract description 26
- 230000006870 function Effects 0.000 claims description 46
- 238000012544 monitoring process Methods 0.000 claims description 4
- 238000005516 engineering process Methods 0.000 abstract description 8
- 230000004044 response Effects 0.000 abstract description 5
- 238000004891 communication Methods 0.000 description 10
- 238000012545 processing Methods 0.000 description 10
- 238000010586 diagram Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 230000003068 static effect Effects 0.000 description 4
- 230000000712 assembly Effects 0.000 description 3
- 238000000429 assembly Methods 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 238000010276 construction Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000002045 lasting effect Effects 0.000 description 1
- 239000012092 media component Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/31—Programming languages or programming paradigms
- G06F8/315—Object-oriented languages
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/34—Graphical or visual programming
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
- G06F8/42—Syntactic analysis
- G06F8/427—Parsing
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Stored Programmes (AREA)
Abstract
本发明揭示了一种业务规则引擎的实现方法及系统,属于计算机应用技术领域。所述方法包括:监听专用web平台的运行,确定新收事件,针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件,对所述规则条件对应的规则动作进行多进程执行。此外,还提供了一种业务规则引擎的实现系统。上述业务规则引擎的实现方法及系统能够减短实现业务规则引擎的响应时间。
Description
技术领域
本发明涉及计算机技术领域,特别涉及一种业务规则引擎的实现方法及系统。
背景技术
业务规则引擎是一项在线运行业务规则的服务。通过将业务规则执行代码与业务流程管理系统的其他代码分开,使业务人员通过规则编辑器灵活编辑、调整业务规则逻辑。
然而,目前的业务规则引擎通常是使用开源的Drools工具而实现的。Drools工具是基于JAVA程序运行的,而由于JAVA程序自身的并发处理限制,在一定的Java Web服务器资源下,业务规则引擎对多进程的响应时间较长,大大影响了业务规则引擎的处理效率。
发明内容
为了解决相关技术中实现业务规则引擎多进程的响应时间较长的技术问题,本发明提供了一种业务规则引擎的实现方法及系统。
本发明实施例提供了一种业务规则引擎的实现方法,包括:
监听专用web平台的运行,确定新收事件;
针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
对所述规则条件对应的规则动作进行多进程执行。
另外,本发明实施例提供了一种业务规则引擎的实现系统,包括:
新收事件确定模块,用于监听专用web平台的运行,确定新收事件;
规则条件确定模块,用于针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
动作执行模块,用于对所述规则条件对应的规则动作进行多进程执行。
此外,本发明实施例还提供了一种系统,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行:
监听专用web平台的运行,确定新收事件;
针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
对所述规则条件对应的规则动作进行多进程执行。
本发明的实施例提供的技术方案可以包括以下有益效果:
在业务规则引擎的实现过程中,监听专用web平台的运行,确定新收事件,针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件,对所述规则条件对应的规则动作进行多进程执行,从而通过专用web平台实现业务规则引擎中的多进程执行,减短了多进程的响应时间,大大影响了业务规则引擎的处理效率。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性的,并不能限制本发明。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
图1是根据一示例性实施例示出的一种业务规则引擎的实现方法流程图。
图2是根据图1对应实施例示出的另一种业务规则引擎的实现方法流程图。
图3是根据图2对应实施例示出的另一种业务规则引擎的实现方法流程图。
图4是图1对应实施例示出的分布式分配方法中步骤S130的一种具体实现流程图。
图5是图4对应实施例示出的分布式分配方法中步骤S132的一种具体实现流程图。
图6是根据一示例性实施例示出的一种业务规则引擎的实现系统框图。
图7是根据图6对应实施例示出的另一种业务规则引擎的实现系统框图。
图8是根据图7对应实施例示出的另一种业务规则引擎的实现系统框图。
图9是图6对应实施例示出的业务规则引擎的实现系统中动作执行模块130的框图。
图10是图9对应实施例示出的业务规则引擎的实现系统中函数对象执行子模块132的框图。
图11是根据一示例性实施例示出的一种系统的结构框图。
具体实施方式
这里将详细地对示例性实施例执行说明,其示例表示在附图中。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
图1是根据一示例性实施例示出的一种业务规则引擎的实现方法流程图。如图1所示,该业务规则引擎的实现方法可以包括以下步骤。
在步骤S110中,监听专用web平台的运行,确定新收事件。
专用web平台是进行web开发的专业平台。通过专用web平台,实现软件的二次开发。
专用web平台采用非编码的方式或者是极少编码的方式,实现资源的共享,从而节约开发成本、提高开发效率、缩短开发周期。
在一具体的示例性实施例中,专用web平台为OpenResty平台。OpenResty平台是一个基于Nginx与Lua的高性能Web平台,其内部集成了大量精良的Lua库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态Web应用、Web服务和动态网关。
OpenResty平台为开源的专用web平台,参考https://openresty.org/cn/getting-started.html学习如何从最简单的hello world开始使用OpenResty开发HTTP业务,或前往https://openresty.org/cn/download.html直接获取OpenResty的源代码包开始体验。
OpenResty是国内注册商标,注册人为章亦春,商标专用期为2016年4月7日至2026年4月6日。
事件可以为专用web平台接收到的执行指令,也可以为其它类型的操作指示。
专用web平台中,根据新收事件,当存在规则条件满足该新收事件时,执行对应的规则动作。
在一具体的示例性实施例中,通过监听OpenResty平台中的消息总线,确定OpenResty平台中新接收的事件。
在步骤S120中,针对业务规则库中的每一个业务规则,对新收事件与业务规则中的规则条件进行匹配运算,确定与新收事件匹配的规则条件。
业务规则库是预先构建的,业务规则库中存储了多种业务规则。
业务规则是与业务相关的操作规范、管理章程、规章制度、行业标准等。业务规则描述了业务过程中重要的且值得记录的对象、关系和活动。其中包括业务操作中的流程、规范与策略。业务规则保证了业务能满足其目标和义务。
业务规则包括规则条件与规则动作等。
规则条件是规则动作触发执行的条件。
业务规则中,规则条件是与规则动作相对应的。当业务规则中的规则条件满足时,则触发执行相应的规则动作。
在步骤S130中,对规则条件对应的规则动作进行多进程执行。
OpenResty平台中,基于Lua(一种脚本语言)实现规则动作的多进程执行。Lua能提供了10K以上的多进程执行,而JAVA能够提供的最大多进程数为500,从而通过Lua大大提高了业务规则引擎的处理能力。
通过如上所述的方法,在OpenResty平台中,基于Lua实现业务规则引擎中的多进程执行,减短了多进程的响应时间,大大影响了业务规则引擎的处理效率。
图2是根据一示例性实施例示出的一种业务规则引擎的实现方法流程图。如图2所示,在图1对应实施例中的步骤S120之前,该业务规则引擎的实现方法还可以包括以下步骤。
在步骤S210中,接收业务规则的界面化编辑。
界面化编辑是在终端显示界面进行的业务规则编辑。
在用户层面,其可通过界面中预置的按钮及输入框,接收输入的相关编辑内容。
在步骤S220中,根据界面化编辑,生成业务规则对应的业务规则代码。
可以理解的是,界面化编辑是面向对象的。
根据面向对象的界面化编辑,利用程序语言将编辑内容映射成相应的业务规则代码。
通过界面化编辑,使业务规则的创建者或维护者无需了解程序语言,就能实现业务规则代码的生成,大大降低了业务规则引擎的使用门槛。
在一具体的示例性实施例中,业务规则代码是业务规则对应的Lua语言代码。
在步骤S230中,将业务规则代码以业务规则为标识存储于业务规则库中。
利用如上所述的方法,通过界面化编辑进行业务规则的创建并存储于业务规则库,大大降低了业务规则引擎的创建及使用门槛,提高了业务规则引擎的使用效率。
图3是根据一示例性实施例示出的一种业务规则引擎的实现方法流程图。如图3所示,在图2对应实施例中的步骤S230之前,该业务规则引擎的实现方法还可以包括以下步骤。
在步骤S310中,接收业务规则库中的更新指令。
可以理解的是,根据实际需要对业务规则库中的业务规则进行更新,从而更好的满足业务需求。
输入更新指令的方式有多种,例如通过界面化编辑输入相应的更新指令,又例如,通过对业务规则对应的代码进行编辑触发输入相应的更新指令。
在步骤S320中,根据规则更新,对相应的业务规则进行代码更新。
利用如上所述的方法,通过接收更新指令对相应的业务规则进行更新,从而使业务规则更加适应实际业务需求,大大提高了业务规则引擎的处理效率。
图4是根据一示例性实施例示出的对步骤S130进一步的细节的描述。该步骤S130可以包括以下步骤。
在步骤S131中,针对每一个与新收事件匹配的规则条件,将规则条件对应的业务规则解析生成对应的函数对象,并存储于内存中。
解析是对业务规则进行语法分析。
函数对象是类对象,表现出一个函数的特征。
函数对象可以定义跨越多次调用的可持久的部分(类似静态局部变量),同时又能从对象的外面进行初始化和检查(和静态局部变量不同),从而通过将业务规则解析生成函数对象,更方便地执行业务规则。
在步骤S132中,对内存中的函数对象进行多进程执行。
由于函数对象存储于内存中,在专用web平台的运行中执行业务规则时,无需频繁地访问磁盘,避免引起磁盘的性能瓶颈,大大提高了利用专用web平实现业务规则引擎的开发效率。
图5根据一示例性实施例示出的对图4中步骤S132进一步的细节描述。业务规则配置有优先级,该步骤S132可以包括以下步骤。
在步骤S1321中,获取内存中每一个函数对象对应的优先级。
优先级是业务规则的执行优先顺序。
业务规则配置有优先级时,在业务规则被解析成函数对象后,该业务规则对应的函数对象将配置相应的优先级。
例如,业务规则A配置的优先级为1,业务规则B配置的优先级为1。将业务规则A解析成函数对象A1、A2、A3,将业务规则B解析成函数对象B1、B2,则函数对象A1、A2、A3对应的优先级为1,而函数对象B1、B2对应的优先级为2。
在步骤S1322中,按照优先级的顺序,进行函数对象的多进程执行。
例如,业务规则A配置的优先级为1,业务规则B配置的优先级为1。将业务规则A解析成函数对象A1、A2、A3,将业务规则B解析成函数对象B1、B2,则函数对象A1、A2、A3对应的优先级为1,而函数对象B1、B2对应的优先级为2。对函数对象A1、A2、A3和函数对象B1、B2执行时,根据优先级顺序,在执行完函数对象A1、A2、A3后,再执行函数对象B1、B2。
利用如上所述的方法,通过获取各函数对象的优先级,并根据优先级顺序进行函数对象的多进程执行,从而更灵活地进行业务规则处理,大大提高了实现业务规则引擎的开发性能。
下述为本发明系统实施例,可以用于执行上述业务规则引擎的实现方法实施例。对于本发明系统实施例中未披露的细节,请参照本发明业务规则引擎的实现方法实施例。
图6是根据一示例性实施例示出的一种业务规则引擎的实现系统框图,该系统包括但不限于:新收事件确定模块110、规则条件确定模块120及动作执行模块130。
新收事件确定模块110,用于监听专用web平台的运行,确定新收事件;
规则条件确定模块120,用于针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
动作执行模块130,用于对所述规则条件对应的规则动作进行多进程执行。
上述系统中各个模块的功能和作用的实现过程具体详见上述业务规则引擎的实现方法中对应步骤的实现过程,在此不再赘述。
图7是根据图6对应实施例示出的一种业务规则引擎的实现系统框图,该系统还包括但不限于:编辑接收模块210、代码生成模块220及规则存储模块230。
编辑接收模块210,用于接收业务规则的界面化编辑;
代码生成模块220,用于根据所述界面化编辑,生成所述业务规则对应的业务规则代码;
规则存储模块230,用于将所述业务规则代码以所述业务规则为标识存储于所述业务规则库中。
图8是根据图7对应实施例示出的一种业务规则引擎的实现系统框图,该系统还包括但不限于:更新指令接收模块310及规则更新模块320。
更新指令接收模块310,用于接收所述业务规则库中的更新指令;
规则更新模块320,用于根据所述更新指令,对相应的业务规则进行更新。
可选的,如图9所示,图6中的动作执行模块130包括但不限于:规则解析子模块131和函数对象执行子模块132。
规则解析子模块131,用于针对每一个与所述新收事件匹配的规则条件,将所述规则条件对应的业务规则解析生成对应的函数对象,并存储于内存中;
函数对象执行子模块132,用于对所述内存中的函数对象进行多进程执行。
可选的,如图10所示,图9中的函数对象执行子模块132包括但不限于:优先级获取单元1321和函数对象执行单元1322。
优先级获取单元1321,用于获取所述内存中每一个函数对象对应的优先级;
函数对象执行单元1322,用于按照所述优先级的顺序,进行函数对象的多进程执行。
图11是根据一示例性实施例示出的一种系统100的框图。参考图11,系统100可以包括以下一个或者多个组件:处理组件101,存储器102,电源组件103,多媒体组件104,音频组件105,传感器组件107以及通信组件108。其中,上述组件并不全是必须的,系统100可以根据自身功能需求增加其他组件或减少某些组件,本实施例不作限定。
处理组件101通常控制系统100的整体操作,诸如与显示,电话呼叫,数据通信,相机操作以及记录操作相关联的操作等。处理组件101可以包括一个或多个处理器109来执行指令,以完成上述操作的全部或部分步骤。此外,处理组件101可以包括一个或多个模块,便于处理组件101和其他组件之间的交互。例如,处理组件101可以包括多媒体模块,以方便多媒体组件104和处理组件101之间的交互。
存储器102被配置为存储各种类型的数据以支持在系统100的操作。这些数据的示例包括用于在系统100上操作的任何应用程序或方法的指令。存储器102可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如SRAM(Static Random AccessMemory,静态随机存取存储器),EEPROM(Electrically Erasable Programmable Read-Only Memory,电可擦除可编程只读存储器),EPROM(Erasable Programmable Read OnlyMemory,可擦除可编程只读存储器),PROM(Programmable Read-Only Memory,可编程只读存储器),ROM(Read-Only Memory,只读存储器),磁存储器,快闪存储器,磁盘或光盘。存储器102中还存储有一个或多个模块,该一个或多个模块被配置成由该一个或多个处理器109执行,以完成图1、图2、图3、图4和图5任一所示方法中的全部或者部分步骤。
电源组件103为系统100的各种组件提供电力。电源组件103可以包括电源管理系统,一个或多个电源,及其他与为系统100生成、管理和分配电力相关联的组件。
多媒体组件104包括在所述系统100和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括LCD(Liquid Crystal Display,液晶显示器)和TP(TouchPanel,触摸面板)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。
音频组件105被配置为输出和/或输入音频信号。例如,音频组件105包括一个麦克风,当系统100处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器102或经由通信组件108发送。在一些实施例中,音频组件105还包括一个扬声器,用于输出音频信号。
传感器组件107包括一个或多个传感器,用于为系统100提供各个方面的状态评估。例如,传感器组件107可以检测到系统100的打开/关闭状态,组件的相对定位,传感器组件107还可以检测系统100或系统100一个组件的位置改变以及系统100的温度变化。在一些实施例中,该传感器组件107还可以包括磁传感器,压力传感器或温度传感器。
通信组件108被配置为便于系统100和其他设备之间有线或无线方式的通信。系统100可以接入基于通信标准的无线网络,如WiFi(WIreless-Fidelity,无线网络),2G或3G,或它们的组合。在一个示例性实施例中,通信组件108经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件108还包括NFC(Near Field Communication,近场通信)模块,以促进短程通信。例如,在NFC模块可基于RFID(Radio Frequency Identification,射频识别)技术,IrDA(Infrared DataAssociation,红外数据协会)技术,UWB(Ultra-Wideband,超宽带)技术,BT(Bluetooth,蓝牙)技术和其他技术来实现。
在示例性实施例中,系统100可以被一个或多个ASIC(Application SpecificIntegrated Circuit,应用专用集成电路)、DSP(Digital Signal Processing,数字信号处理器)、PLD(Programmable Logic Device,可编程逻辑器件)、FPGA(Field-ProgrammableGate Array,现场可编程门阵列)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
该实施例中的系统的处理器执行操作的具体方式已经在有关该业务规则引擎的实现方法的实施例中执行了详细描述,此处将不再做详细阐述说明。
可选的,本发明还提供一种系统,执行图1、图2、图3、图4和图5任一所示的业务规则引擎的实现方法的全部或者部分步骤。所述系统包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行:
监听专用web平台的运行,确定新收事件;
针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
对所述规则条件对应的规则动作进行多进程执行。
该实施例中的系统的处理器执行操作的具体方式已经在有关该业务规则引擎的实现方法的实施例中执行了详细描述,此处将不做详细阐述说明。
在示例性实施例中,还提供了一种存储介质,该存储介质为计算机可读存储介质,例如可以为包括指令的临时性和非临时性计算机可读存储介质。该存储介质例如包括指令的存储器102,上述指令可由系统100的处理器109执行以完成上述业务规则引擎的实现方法。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,本领域技术人员可以在不脱离其范围执行各种修改和改变。本发明的范围仅由所附的权利要求来限制。
Claims (11)
1.一种业务规则引擎的实现方法,其特征在于,所述方法包括:
监听专用web平台的运行,确定新收事件;
针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
对所述规则条件对应的规则动作进行多进程执行。
2.根据权利要求1所述的方法,其特征在于,所述针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,得到与所述新收事件匹配的规则条件的步骤之前,所述方法还包括:
接收业务规则的界面化编辑;
根据所述界面化编辑,生成所述业务规则对应的业务规则代码;
将所述业务规则代码以所述业务规则为标识存储于所述业务规则库中。
3.根据权利要求2所述的方法,其特征在于,所述将所述业务规则代码以所述业务规则为标识存储于所述业务规则库中的步骤之后,所述方法还包括:
接收所述业务规则库中的更新指令;
根据所述更新指令,对相应的业务规则进行更新。
4.根据权利要求1所述的方法,其特征在于,所述对所述规则条件对应的规则动作进行多进程执行的步骤包括:
针对每一个与所述新收事件匹配的规则条件,将所述规则条件对应的业务规则解析生成对应的函数对象,并存储于内存中;
对所述内存中的函数对象进行多进程执行。
5.根据权利要求4所述的方法,其特征在于,所述业务规则配置有优先级,所述对所述内存中的函数对象进行多进程执行的步骤包括:
获取所述内存中每一个函数对象对应的优先级;
按照所述优先级的顺序,进行函数对象的多进程执行。
6.一种业务规则引擎的实现系统,其特征在于,所述系统包括:
新收事件确定模块,用于监听专用web平台的运行,确定新收事件;
规则条件确定模块,用于针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
动作执行模块,用于对所述规则条件对应的规则动作进行多进程执行。
7.根据权利要求6所述的系统,其特征在于,所述系统还包括:
编辑接收模块,用于接收业务规则的界面化编辑;
代码生成模块,用于根据所述界面化编辑,生成所述业务规则对应的业务规则代码;
规则存储模块,用于将所述业务规则代码以所述业务规则为标识存储于所述业务规则库中。
8.根据权利要求7所述的系统,其特征在于,所述系统还包括:
更新指令接收模块,用于接收所述业务规则库中的更新指令;
规则更新模块,用于根据所述更新指令,对相应的业务规则进行更新。
9.根据权利要求6所述的系统,其特征在于,所述动作执行模块包括:
规则解析子模块,用于针对每一个与所述新收事件匹配的规则条件,将所述规则条件对应的业务规则解析生成对应的函数对象,并存储于内存中;
函数对象执行子模块,用于对所述内存中的函数对象进行多进程执行。
10.根据权利要求9所述的系统,其特征在于,所述函数对象执行子模块包括:
优先级获取单元,用于获取所述内存中每一个函数对象对应的优先级;
函数对象执行单元,用于按照所述优先级的顺序,进行函数对象的多进程执行。
11.一种系统,其特征在于,所述系统包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行:
监听专用web平台的运行,确定新收事件;
针对业务规则库中的每一个业务规则,对所述新收事件与所述业务规则中的规则条件进行匹配运算,确定与所述新收事件匹配的规则条件;
对所述规则条件对应的规则动作进行多进程执行。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710414953.6A CN107220058A (zh) | 2017-06-05 | 2017-06-05 | 业务规则引擎的实现方法及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710414953.6A CN107220058A (zh) | 2017-06-05 | 2017-06-05 | 业务规则引擎的实现方法及系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN107220058A true CN107220058A (zh) | 2017-09-29 |
Family
ID=59947376
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710414953.6A Pending CN107220058A (zh) | 2017-06-05 | 2017-06-05 | 业务规则引擎的实现方法及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107220058A (zh) |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108008944A (zh) * | 2017-11-29 | 2018-05-08 | 千寻位置网络有限公司 | 规则引擎响应方法及系统、规则引擎、服务终端、存储器 |
CN108229907A (zh) * | 2017-12-06 | 2018-06-29 | 链家网(北京)科技有限公司 | 一种基于表达式引擎的规则变更方法和系统 |
CN108595566A (zh) * | 2018-04-13 | 2018-09-28 | 中国民航信息网络股份有限公司 | 信息聚类方法及装置 |
CN108846630A (zh) * | 2018-05-25 | 2018-11-20 | 广州衡昊数据科技有限公司 | 一种资源控制系统及方法 |
CN109144493A (zh) * | 2018-07-18 | 2019-01-04 | 平安科技(深圳)有限公司 | 业务规则的生成方法、电子装置及可读存储介质 |
CN109144374A (zh) * | 2018-09-27 | 2019-01-04 | 范若愚 | 基于可视化规则引擎的业务处理方法、系统及相关设备 |
CN109376988A (zh) * | 2018-09-11 | 2019-02-22 | 阿里巴巴集团控股有限公司 | 一种业务数据的处理方法和装置 |
CN109493213A (zh) * | 2018-11-09 | 2019-03-19 | 杭州创金聚乾网络科技有限公司 | 一种基于业务规则库的借贷业务决策方法及系统 |
CN109542432A (zh) * | 2018-10-16 | 2019-03-29 | 深圳壹账通智能科技有限公司 | 风控规则编辑方法及终端设备 |
CN109542559A (zh) * | 2018-10-31 | 2019-03-29 | 微服云联科技(深圳)有限公司 | 看板卡片的处理方法、装置、计算机设备和存储介质 |
CN110443512A (zh) * | 2019-08-09 | 2019-11-12 | 北京思维造物信息科技股份有限公司 | 一种规则引擎及规则引擎实现方法 |
CN110647546A (zh) * | 2019-09-18 | 2020-01-03 | 北京明略软件系统有限公司 | 第三方规则引擎生成方法及装置 |
CN111311319A (zh) * | 2020-02-13 | 2020-06-19 | 安超云软件有限公司 | 产品活动信息的配置方法以及系统 |
CN112416383A (zh) * | 2020-01-21 | 2021-02-26 | 上海哔哩哔哩科技有限公司 | golang程序热更新方法、装置以及计算机设备 |
CN113065656A (zh) * | 2021-03-26 | 2021-07-02 | 龙马智芯(珠海横琴)科技有限公司 | 一种规则引擎配置方法、装置、服务器及可读存储介质 |
CN114201254A (zh) * | 2021-12-06 | 2022-03-18 | 上海中通吉网络技术有限公司 | 业务规则引擎的实现方法及架构 |
CN114329114A (zh) * | 2021-12-29 | 2022-04-12 | 傲普(上海)新能源有限公司 | Ems系统位置与规则匹配方法和规则引擎装置 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101101651A (zh) * | 2007-08-01 | 2008-01-09 | 中兴通讯股份有限公司 | 一种电子工单数据的转换处理方法、系统及转换规则引擎 |
US20090113387A1 (en) * | 2007-10-29 | 2009-04-30 | Sap Ag | Methods and systems for dynamically generating and optimizing code for business rules |
CN102360291B (zh) * | 2011-10-07 | 2013-11-13 | 云南爱迪科技有限公司 | 面向服务的基于业务规则引擎的业务规则设计方法 |
CN103473642A (zh) * | 2013-09-10 | 2013-12-25 | 中国科学院沈阳自动化研究所 | 一种面向生产调度的规则引擎方法 |
CN104966239A (zh) * | 2015-06-30 | 2015-10-07 | 天津爱蔻科技有限公司 | 一种基于规则引擎的智能核保平台 |
CN105227571A (zh) * | 2015-10-20 | 2016-01-06 | 福建六壬网安股份有限公司 | 基于nginx+lua的web应用防火墙系统及其实现方法 |
-
2017
- 2017-06-05 CN CN201710414953.6A patent/CN107220058A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101101651A (zh) * | 2007-08-01 | 2008-01-09 | 中兴通讯股份有限公司 | 一种电子工单数据的转换处理方法、系统及转换规则引擎 |
US20090113387A1 (en) * | 2007-10-29 | 2009-04-30 | Sap Ag | Methods and systems for dynamically generating and optimizing code for business rules |
CN102360291B (zh) * | 2011-10-07 | 2013-11-13 | 云南爱迪科技有限公司 | 面向服务的基于业务规则引擎的业务规则设计方法 |
CN103473642A (zh) * | 2013-09-10 | 2013-12-25 | 中国科学院沈阳自动化研究所 | 一种面向生产调度的规则引擎方法 |
CN104966239A (zh) * | 2015-06-30 | 2015-10-07 | 天津爱蔻科技有限公司 | 一种基于规则引擎的智能核保平台 |
CN105227571A (zh) * | 2015-10-20 | 2016-01-06 | 福建六壬网安股份有限公司 | 基于nginx+lua的web应用防火墙系统及其实现方法 |
Cited By (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108008944A (zh) * | 2017-11-29 | 2018-05-08 | 千寻位置网络有限公司 | 规则引擎响应方法及系统、规则引擎、服务终端、存储器 |
CN108229907A (zh) * | 2017-12-06 | 2018-06-29 | 链家网(北京)科技有限公司 | 一种基于表达式引擎的规则变更方法和系统 |
CN108595566A (zh) * | 2018-04-13 | 2018-09-28 | 中国民航信息网络股份有限公司 | 信息聚类方法及装置 |
CN108846630A (zh) * | 2018-05-25 | 2018-11-20 | 广州衡昊数据科技有限公司 | 一种资源控制系统及方法 |
CN108846630B (zh) * | 2018-05-25 | 2022-06-03 | 广州衡昊数据科技有限公司 | 一种资源控制系统及方法 |
CN109144493A (zh) * | 2018-07-18 | 2019-01-04 | 平安科技(深圳)有限公司 | 业务规则的生成方法、电子装置及可读存储介质 |
CN109376988A (zh) * | 2018-09-11 | 2019-02-22 | 阿里巴巴集团控股有限公司 | 一种业务数据的处理方法和装置 |
CN109144374A (zh) * | 2018-09-27 | 2019-01-04 | 范若愚 | 基于可视化规则引擎的业务处理方法、系统及相关设备 |
CN109542432A (zh) * | 2018-10-16 | 2019-03-29 | 深圳壹账通智能科技有限公司 | 风控规则编辑方法及终端设备 |
CN109542559A (zh) * | 2018-10-31 | 2019-03-29 | 微服云联科技(深圳)有限公司 | 看板卡片的处理方法、装置、计算机设备和存储介质 |
CN109493213A (zh) * | 2018-11-09 | 2019-03-19 | 杭州创金聚乾网络科技有限公司 | 一种基于业务规则库的借贷业务决策方法及系统 |
CN110443512A (zh) * | 2019-08-09 | 2019-11-12 | 北京思维造物信息科技股份有限公司 | 一种规则引擎及规则引擎实现方法 |
CN110647546A (zh) * | 2019-09-18 | 2020-01-03 | 北京明略软件系统有限公司 | 第三方规则引擎生成方法及装置 |
CN112416383A (zh) * | 2020-01-21 | 2021-02-26 | 上海哔哩哔哩科技有限公司 | golang程序热更新方法、装置以及计算机设备 |
CN111311319A (zh) * | 2020-02-13 | 2020-06-19 | 安超云软件有限公司 | 产品活动信息的配置方法以及系统 |
CN111311319B (zh) * | 2020-02-13 | 2023-09-15 | 安超云软件有限公司 | 产品活动信息的配置方法以及系统 |
CN113065656A (zh) * | 2021-03-26 | 2021-07-02 | 龙马智芯(珠海横琴)科技有限公司 | 一种规则引擎配置方法、装置、服务器及可读存储介质 |
CN114201254A (zh) * | 2021-12-06 | 2022-03-18 | 上海中通吉网络技术有限公司 | 业务规则引擎的实现方法及架构 |
CN114329114A (zh) * | 2021-12-29 | 2022-04-12 | 傲普(上海)新能源有限公司 | Ems系统位置与规则匹配方法和规则引擎装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107220058A (zh) | 业务规则引擎的实现方法及系统 | |
CN107864065B (zh) | 无埋点数据采集方法、系统及计算机可读存储介质 | |
CN107450899B (zh) | 终端控制脚本的生成方法和装置 | |
CN107423106A (zh) | 支持多框架语法的方法和装置 | |
TW200614767A (en) | Method and system for data authorization and mobile device using the same | |
WO2014086238A1 (zh) | 语音后台控制方法及移动终端 | |
CN107591152A (zh) | 基于耳机的语音控制方法、装置及其设备 | |
CN107945029A (zh) | 保险产品的推送方法、系统、终端、客户终端及存储介质 | |
CN108572908B (zh) | 信息反馈方法及装置 | |
CN107066229A (zh) | 录音的方法及终端 | |
CN107526605A (zh) | 实现应用程序加载服务组件的方法和装置 | |
CN105094830B (zh) | 一种执行目标功能的方法和装置 | |
CN110347548A (zh) | 一种异常检测方法及装置、存储介质、电子设备 | |
CN105183571A (zh) | 函数调用方法和装置 | |
CN110168496A (zh) | 用于应用呈现的方法和系统 | |
CN110213163A (zh) | 一种基于nginx和zuul的路由转发方法及装置 | |
CN104866406A (zh) | 一种基于指纹识别的提示方法及终端 | |
CN114115866A (zh) | 基于跨域的车载场景自定义方法、装置、设备及存储介质 | |
CN107077844A (zh) | 语音联合协助的实现方法、装置及机器人 | |
CN107945552A (zh) | 对信号灯变灯时间进行提示的方法、装置及存储介质 | |
CN107463372A (zh) | 一种数据驱动的页面更新方法和装置 | |
CN107544802A (zh) | 设备识别方法及装置 | |
CN107423059A (zh) | 页面的显示方法、装置及终端 | |
CN104899059B (zh) | 操作系统升级方法及装置 | |
CN105529025A (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 | ||
CB02 | Change of applicant information |
Address after: 361000 Area 1F-D1, Huaxun Building A, Software Park, Xiamen Torch High-tech Zone, Xiamen City, Fujian Province Applicant after: Xiamen Meishao Co.,Ltd. Address before: Unit G03, Room 102, 22 Guanri Road, Phase II, Xiamen Software Park, Fujian Province Applicant before: XIAMEN MEIYOU INFORMATION SCIENCE & TECHNOLOGY Co.,Ltd. |
|
CB02 | Change of applicant information | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20170929 |
|
RJ01 | Rejection of invention patent application after publication |