CN116939014A - 系统事件的解耦控制分发方法、装置、设备及存储介质 - Google Patents
系统事件的解耦控制分发方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN116939014A CN116939014A CN202310851712.3A CN202310851712A CN116939014A CN 116939014 A CN116939014 A CN 116939014A CN 202310851712 A CN202310851712 A CN 202310851712A CN 116939014 A CN116939014 A CN 116939014A
- Authority
- CN
- China
- Prior art keywords
- event
- service
- message
- center
- target
- 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 51
- 238000004458 analytical method Methods 0.000 claims abstract description 23
- 238000012544 monitoring process Methods 0.000 claims abstract description 14
- 238000007726 management method Methods 0.000 claims description 24
- 238000012545 processing Methods 0.000 claims description 14
- 230000005540 biological transmission Effects 0.000 claims description 11
- 238000004590 computer program Methods 0.000 claims description 9
- 230000008859 change Effects 0.000 claims description 8
- 230000000007 visual effect Effects 0.000 claims description 4
- 238000005516 engineering process Methods 0.000 abstract description 5
- 238000012423 maintenance Methods 0.000 abstract description 5
- 238000004891 communication Methods 0.000 description 12
- 230000006870 function Effects 0.000 description 10
- 238000013473 artificial intelligence Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 4
- 230000007246 mechanism Effects 0.000 description 4
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 239000008186 active pharmaceutical agent Substances 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 239000003795 chemical substances by application Substances 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000000802 evaporation-induced self-assembly Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005192 partition Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/51—Discovery or management thereof, e.g. service location protocol [SLP] or web services
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/133—Protocols for remote procedure calls [RPC]
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明涉及基架运维及数字医疗技术,揭露了用于医疗系统进行业务更新、维护场景的一种系统事件的解耦控制分发方法、装置、设备及存储介质。所述方法包括:监听目标微服务的消息队列;当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。本发明可以在复杂的医疗系统中,对以主题为单位的解耦方式进行进一步的解耦,提高代码的可复用性和可维护性。
Description
技术领域
本发明涉及基架运维及数字医疗技术领域,尤其涉及用于医疗系统进行业务更新、维护场景的一种系统事件的解耦控制分发方法、装置、设备及计算机可读存储介质。
背景技术
随着网络科技的发展,各行各业系统中的微服务越来越多,例如一个医疗系统处自身数据统计服务外,还接入了医疗问诊APP的微服务,其中,医疗问诊APP的微服务中还包括APP生命周期控制服务(App启动、App进入前台、App进入后台、App将要被杀死)、账户登录推出管理服务(用户手动登录成功、用户自动登录成功、用户即将推出登录、用户已经退出登录)等。
如今多个微服务的消息会被存储在同一个主题中的不同分区中,从而对不同微服务之间的消息进行解耦,然而,解耦并不仅仅是指消息的存储和分发方式,还包括微服务之间的接口定义、数据格式、消息协议等方面。一个大的不同业务的代码混在一个主题或者方法里面,耦合度仍然太高,改动一个业务代码很容易影响到其他的业务,因此,需要更高级别的解耦性。
发明内容
本发明提供一种系统事件的解耦控制分发方法、装置、设备及存储介质,其主要目的在于在复杂的医疗系统中,对以主题为单位的解耦方式进行进一步的解耦,提高代码的可复用性和可维护性。
为实现上述目的,本发明提供的一种系统事件的解耦控制分发方法,包括:
监听目标微服务的消息队列;
当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
可选的,所述从预构建的事件中心中调用事件发送服务之前,所述方法还包括:
获取预构建的事件中心,利用所述事件中心,对预构建的微服务业务集群进行业务注册,得到业务消息列表,并监听所述业务消息列表;
根据预设的事件检索分发策略,在所述事件中心中构建事件发送服务,并根据所述业务消息列表配置所述事件发送服务的调用白名单。
可选的,所述当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,包括:
判断所述目标微服务的服务类型;
当所述目标微服务为账户登录服务时,拦截所述账户登录服务中登录接口和登出接口的调用,得到账户登录状态,当所述账户登录状态发生改变时,生成基于登录状态变化的事件消息,并利用所述账户登录服务中的网络库调用预构建的事件中心的事件发送服务;
当所述目标微服务为APP生命管理服务时,利用所述APP生命管理服务的代理对象服务调用预构建的事件中心的事件发送服务。
可选的,其特征在于,所述利用所述事件发送服务将所述事件消息配置为事件对象之后,所述方法还包括:
获取所述事件对象所在的业务消息列表的文件路径,根据所述文件路径配置预构建的消息采集器,及利用预设的文件创建脚本,构建Kafka服务的主题文件;
利用配置好的所述消息采集器,将所述业务消息列表导入所述主题文件中;
利用所述Kafka服务中的Kafka Connect组件,将所述主题文件配置到预构建的流处理工具,并利用所述流处理工具对所述主题文件进行可视化内容统计。
可选的,所述根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中,包括:
获取所述事件解析结果中的有效关键字,根据所述有效关键字遍历所述业务消息列表,得到目标业务信息;
将所述事件对象分发至所述目标业务信息对应的目标业务服务中。
为了解决上述问题,本发明还提供一种系统事件的解耦控制分发装置,所述装置包括:
数据获取模块,用于监听目标微服务的消息队列;
数据传输模块,用于当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
数据分发模块,用于利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
可选的,所述从预构建的事件中心中调用事件发送服务之前,所述方法还包括:
获取预构建的事件中心,利用所述事件中心,对预构建的微服务业务集群进行业务注册,得到业务消息列表,并监听所述业务消息列表;
根据预设的事件检索分发策略,在所述事件中心中构建事件发送服务,并根据所述业务消息列表配置所述事件发送服务的调用白名单。
可选的,所述当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,包括:
判断所述目标微服务的服务类型;
当所述目标微服务为账户登录服务时,拦截所述账户登录服务中登录接口和登出接口的调用,得到账户登录状态,当所述账户登录状态发生改变时,生成基于登录状态变化的事件消息,并利用所述账户登录服务中的网络库调用预构建的事件中心的事件发送服务;
当所述目标微服务为APP生命管理服务时,利用所述APP生命管理服务的代理对象服务调用预构建的事件中心的事件发送服务。
为了解决上述问题,本发明还提供一种电子设备,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行上述所述的系统事件的解耦控制分发方法。
为了解决上述问题,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质中存储有至少一个计算机程序,所述至少一个计算机程序被电子设备中的处理器执行以实现上述所述的系统事件的解耦控制分发方法。
本发明首先构建一个事件中心,并在事件中心中配置一个调用事件发送服务及一个业务消息列表,然后本发明通过医疗系统下的微服务业务集群在所述业务消息列表进行进行注册;当微服务业务集群中的一个目标微服务发生事件消息时,可以通过调用所述调用事件发送服务将事件消息发送到事件中心,然后通过遍历业务消息列表,找到事件消息对应的目标业务服务并发送过去,通过业务消息列表实现事件的管理与分发;当对所述医疗系统的某个业务进行维护时,只需更改所述业务消息列表中的业务注册信息,即可对目标业务进行代码改动,不影响其他业务,从而进一步提高业务之间的解耦性;此外,本发明实施例通过调用事件发送服务的方法,使得各个目标微服务不需要直接知道接收方的存在和实现细节,即可完成事件传输,进一步提高解耦行,而且使用事件发送服务,可以方便地添加新的事件监听器,进一步增加业务的可扩展性。因此,本发明实施例提供的一种系统事件的解耦控制分发方法、装置、设备及存储介质,能够在于在复杂的医疗系统中,对以主题为单位的解耦方式进行进一步的解耦,提高代码的可复用性和可维护性。
附图说明
图1为本发明一实施例提供的系统事件的解耦控制分发方法的流程示意图;
图2为本发明一实施例提供的系统事件的解耦控制分发方法中一个步骤的详细流程示意图;
图3为本发明一实施例提供的系统事件的解耦控制分发方法中一个步骤的详细流程示意图;
图4为本发明一实施例提供的系统事件的解耦控制分发装置的功能模块图;
图5为本发明一实施例提供的实现所述系统事件的解耦控制分发方法的电子设备的结构示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本申请实施例提供一种系统事件的解耦控制分发方法。本申请实施例中,所述系统事件的解耦控制分发方法的执行主体包括但不限于服务端、终端等能够被配置为执行本申请实施例提供的该方法的电子设备中的至少一种。换言之,所述系统事件的解耦控制分发方法可以由安装在终端设备或服务端设备的软件或硬件来执行,所述软件可以是区块链平台。所述服务端包括但不限于:单台服务器、服务器集群、云端服务器或云端服务器集群等。所述服务器可以是独立的服务器,也可以是提供云服务、云数据库、云计算、云函数、云存储、网络服务、云通信、中间件服务、域名服务、安全服务、内容分发网络(ContentDelivery Network,CDN)、以及大数据和人工智能平台等基础云计算服务的云服务器。
参照图1所示,为本发明一实施例提供的系统事件的解耦控制分发方法的流程示意图。在本实施例中,所述系统事件的解耦控制分发方法包括步骤S1~S4:
S1、监听目标微服务的消息队列。
本发明实施例中,所述目标微服务是指目标医疗系统下微服务业务集群中的一个功能服务,例如APP生命周期控制服务(App启动、App进入前台、App进入后台、App将要被杀死)、账户登录推出管理服务(用户手动登录成功、用户自动登录成功、用户即将推出登录、用户已经退出登录)等。
进一步的,本发明实施例中通过MQ(Message Queue)构建所述消息队列,所述MQ是一种用于分布式应用程序中传递消息的中间件,可以实现不同应用程序之间的解耦和异步通信。
具体的,本发明实施例通过监听器对目标微服务的消息队列进行监听。其中,所述监听器是一种常见的解耦机制,用于在事件发生时接收和处理事件。
S2、判断所述消息队列中是否出现事件消息;
本发明实施例中,根据预设的时间频率对所述消息队列进行持续监听,直至监听到事件消息,例如,所述时间频率可以为30帧/秒。
当所述消息队列中出现事件消息时,S3、从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象。
本发明实施例中,所述目标微服务主要分为两类事件管理及通知机制,所述事件管理指应用程序中各个模块之间通过事件中心进行事件的注册、发送和监听,从而实现模块间的解耦和通信,例如账户登录服务;所述通知机制指应用程序中各个模块之间通过事件中心发送和接收通知,以实现模块间的信息传递和状态更新,例如APP生命管理服务。
详细的,参考图2所示,本发明实施例中,所述当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,包括步骤S31~S33:
S31、判断所述目标微服务的服务类型;
当所述目标微服务为账户登录服务时,S32、拦截所述账户登录服务中登录接口和登出接口的调用,得到账户登录状态,当所述账户登录状态发生改变时,生成基于登录状态变化的事件消息,并利用所述账户登录服务中的网络库调用预构建的事件中心的事件发送服务;
当所述目标微服务为APP生命管理服务时,S33、利用所述APP生命管理服务的代理对象服务调用预构建的事件中心的事件发送服务。
具体的,本发明实施例中判断目标微服务的服务类型,当所述目标微服务为账户登录服务时,可以在网络库(Network Library)中拦截用户登录、登出接口的调用,用来感知用户登录状态发生变化的时机,并发送给事件中心。其中,所述网络库是一种用于处理网络通信的软件库或框架,提供了一组API和工具,用于简化网络通信的操作和管理。
本发明实施例拦截用户登录、登出接口的调用,除了可以感知用户的登录状态外,还可以进行用户鉴权,验证用户的身份和权限。例如,在用户登录时,网络库可以验证用户提供的凭证,判断登录是否有效。
进一步的,本发明实施例中,当所述目标微服务为APP生命管理服务时,可以利用代理对象服务AppDelegate事件发送服务,将App发生生命周期变化的事件告知到事件中心。其中,所述AppDelegate是iOS应用程序的代理对象,是一个遵循UIApplicationDelegate协议的类。在iOS应用程序的生命周期中,AppDelegate负责处理和管理应用程序的各种事件和状态变化。
详细的,参考图3所示,本发明实施例中,所述从预构建的事件中心中调用事件发送服务之前,所述方法还包括步骤S301~S302:
S301、获取预构建的事件中心,利用所述事件中心,对预构建的微服务业务集群进行业务注册,得到业务消息列表,并监听所述业务消息列表;
S302、根据预设的事件检索分发策略,在所述事件中心中构建事件发送服务,并根据所述业务消息列表配置所述事件发送服务的调用白名单。
具体的,本发明创建一个名为EventCenter的类,作为事件中心。不同的医疗业务服务可以调用EventCenter的注册方法,将自己注册到事件中心中,告知事件中心在发生特定事件时需要通知它们。事件中心会将注册的业务方保存在一个业务消息列表ListenerList中。当事件中心接收到App生命周期变化或用户登录状态发生改变的事件时,可以遍历ListenerList数组,将事件转发给相应的业务模块。
S4、利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
本发明实施例中,当事件中心接收到App生命周期变化或用户登录状态发生改变的事件时,可以对所述事件对象进行解析,得到事件解析结果,例如问诊单号,用户ID,性别,年龄等用户信息字段,咨询主诉,医生ID,医生姓名等医生信息字段,问诊状态,渠道APPID等表结构字段。
进一步的,本发明实施例中,所述根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中,包括:
获取所述事件解析结果中的有效关键字,根据所述有效关键字遍历所述业务消息列表,得到目标业务信息;
将所述事件对象分发至所述目标业务信息对应的目标业务服务中。
本发明实施例根据问诊单号、问诊状态等关键词作为有效关键字,然后通过关键字确定目标业务信息,然后目标业务服务作为目标传输事件对象。
此外,本发明另一实施例中,所述利用所述事件发送服务将所述事件消息配置为事件对象之后,所述方法还包括:
获取所述事件对象所在的业务消息列表的文件路径,根据所述文件路径配置预构建的消息采集器,及利用预设的文件创建脚本,构建Kafka服务的主题文件;
利用配置好的所述消息采集器,将所述业务消息列表导入所述主题文件中;
利用所述Kafka服务中的Kafka Connect组件,将所述主题文件配置到预构建的流处理工具,并利用所述流处理工具对所述主题文件进行可视化内容统计。
其中,所述Kafka服务是一个分布式的消息队列服务,可以实现高吞吐量、低延迟、可靠性和可扩展性的消息传递服务,本发明实施例通过Kafka服务可以高效对事件消息进行提取,增加提醒响应速度。本发明实施例中的消息采集器采用filebeat,所述filebeat是一个轻量级的日志数据收集器,可以实时收集服务器上的日志事件,并将其发送到指定的目的地。本发明实施例将业务消息列表中的事件消息写入Kafka服务的Topic文件中。
然后,本发明实施例利用所述Kafka服务中的Kafka Connect组件及流处理工具对所述主题文件进行可视化。其中,所述Kafka Connect组件用于将Kafka与外部系统进行连接;所述流处理工具可以为Apache Flink、Apache Spark等,这些流处理工具都提供了丰富的数据处理和统计功能,可以对所述事件消息进行实时计算和可视化,增加业务维护人员对于医疗系统的把控力度,增加系统稳定性。
本发明首先构建一个事件中心,并在事件中心中配置一个调用事件发送服务及一个业务消息列表,然后本发明通过医疗系统下的微服务业务集群在所述业务消息列表进行进行注册;当微服务业务集群中的一个目标微服务发生事件消息时,可以通过调用所述调用事件发送服务将事件消息发送到事件中心,然后通过遍历业务消息列表,找到事件消息对应的目标业务服务并发送过去,通过业务消息列表实现事件的管理与分发;当对所述医疗系统的某个业务进行维护时,只需更改所述业务消息列表中的业务注册信息,即可对目标业务进行代码改动,不影响其他业务,从而进一步提高业务之间的解耦性;此外,本发明实施例通过调用事件发送服务的方法,使得各个目标微服务不需要直接知道接收方的存在和实现细节,即可完成事件传输,进一步提高解耦行,而且使用事件发送服务,可以方便地添加新的事件监听器,进一步增加业务的可扩展性。因此,本发明实施例提供的一种系统事件的解耦控制分发方法,能够在于在复杂的医疗系统中,对以主题为单位的解耦方式进行进一步的解耦,提高代码的可复用性和可维护性。
如图4所示,是本发明一实施例提供的系统事件的解耦控制分发装置的功能模块图。
本发明所述系统事件的解耦控制分发装置100可以安装于电子设备中。根据实现的功能,所述系统事件的解耦控制分发装置100可以数据获取模块101、数据传输模块102及数据分发模块103。本发明所述模块也可以称之为单元,是指一种能够被电子设备处理器所执行,并且能够完成固定功能的一系列计算机程序段,其存储在电子设备的存储器中。
在本实施例中,关于各模块/单元的功能如下:
所述数据获取模块101,用于监听目标微服务的消息队列;
所述数据传输模块102,用于当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
所述数据分发模块103,用于利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
详细地,本申请实施例中所述系统事件的解耦控制分发装置100中所述的各模块在使用时采用与上述图1至图3中所述的系统事件的解耦控制分发方法一样的技术手段,并能够产生相同的技术效果,这里不再赘述。
如图5所示,是本发明一实施例提供的实现系统事件的解耦控制分发方法的电子设备1的结构示意图。
所述电子设备1可以包括处理器10、存储器11、通信总线12以及通信接口13,还可以包括存储在所述存储器11中并可在所述处理器10上运行的计算机程序,如系统事件的解耦控制分发程序。
其中,所述处理器10在一些实施例中可以由集成电路组成,例如可以由单个封装的集成电路所组成,也可以是由多个相同功能或不同功能封装的集成电路所组成,包括一个或者多个中央处理器(Central Processing Unit,CPU)、微处理器、数字处理芯片、图形处理器及各种控制芯片的组合等。所述处理器10是所述电子设备1的控制核心(ControlUnit),利用各种接口和线路连接整个电子设备的各个部件,通过运行或执行存储在所述存储器11内的程序或者模块(例如执行系统事件的解耦控制分发程序等),以及调用存储在所述存储器11内的数据,以执行电子设备的各种功能和处理数据。
所述存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、移动硬盘、多媒体卡、卡型存储器(例如:SD或DX存储器等)、磁性存储器、磁盘、光盘等。所述存储器11在一些实施例中可以是电子设备的内部存储单元,例如该电子设备的移动硬盘。所述存储器11在另一些实施例中也可以是电子设备的外部存储设备,例如电子设备上配备的插接式移动硬盘、智能存储卡(Smart Media Card,SMC)、安全数字(Secure Digital,SD)卡、闪存卡(Flash Card)等。进一步地,所述存储器11还可以既包括电子设备的内部存储单元也包括外部存储设备。所述存储器11不仅可以用于存储安装于电子设备的应用软件及各类数据,例如系统事件的解耦控制分发程序的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
所述通信总线12可以是外设部件互连标准(Peripheral ComponentInterconnect,简称PCI)总线或扩展工业标准结构(Extended Industry StandardArchitecture,简称EISA)总线等。该总线可以分为地址总线、数据总线、控制总线等。所述总线被设置为实现所述存储器11以及至少一个处理器10等之间的连接通信。
所述通信接口13用于上述电子设备1与其他设备之间的通信,包括网络接口和用户接口。可选地,所述网络接口可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该电子设备与其他电子设备之间建立通信连接。所述用户接口可以是显示器(Display)、输入单元(比如键盘(Keyboard)),可选地,用户接口还可以是标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在电子设备中处理的信息以及用于显示可视化的用户界面。
图5仅示出了具有部件的电子设备,本领域技术人员可以理解的是,图5示出的结构并不构成对所述电子设备1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
例如,尽管未示出,所述电子设备1还可以包括给各个部件供电的电源(比如电池),优选地,电源可以通过电源管理装置与所述至少一个处理器10逻辑相连,从而通过电源管理装置实现充电管理、放电管理、以及功耗管理等功能。电源还可以包括一个或一个以上的直流或交流电源、再充电装置、电源故障检测电路、电源转换器或者逆变器、电源状态指示器等任意组件。所述电子设备1还可以包括多种传感器、蓝牙模块、Wi-Fi模块等,在此不再赘述。
应该了解,所述实施例仅为说明之用,在专利申请范围上并不受此结构的限制。
所述电子设备1中的所述存储器11存储的系统事件的解耦控制分发程序是多个指令的组合,在所述处理器10中运行时,可以实现:
监听目标微服务的消息队列;
当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
具体地,所述处理器10对上述指令的具体实现方法可参考附图对应实施例中相关步骤的描述,在此不赘述。
进一步地,所述电子设备1集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读存储介质中。所述计算机可读存储介质可以是易失性的,也可以是非易失性的。例如,所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)。
本发明还提供一种计算机可读存储介质,所述可读存储介质存储有计算机程序,所述计算机程序在被电子设备的处理器所执行时,可以实现:
监听目标微服务的消息队列;
当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
在本发明所提供的几个实施例中,应该理解到,所揭露的设备,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能模块的形式实现。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。
因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化涵括在本发明内。不应将权利要求中的任何附关联图标记视为限制所涉及的权利要求。
本发明所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
本申请实施例可以基于人工智能技术对相关的数据进行获取和处理。其中,人工智能(Artificial Intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用系统。
此外,显然“包括”一词不排除其他单元或步骤,单数不排除复数。系统权利要求中陈述的多个单元或装置也可以由一个单元或装置通过软件或者硬件来实现。第一、第二等词语用来表示名称,而并不表示任何特定的顺序。
最后应说明的是,以上实施例仅用以说明本发明的技术方案而非限制,尽管参照较佳实施例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或等同替换,而不脱离本发明技术方案的精神和范围。
Claims (10)
1.一种系统事件的解耦控制分发方法,其特征在于,所述方法包括:
监听目标微服务的消息队列;
当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
2.如权利要求1所述的系统事件的解耦控制分发方法,其特征在于,所述从预构建的事件中心中调用事件发送服务之前,所述方法还包括:
获取预构建的事件中心,利用所述事件中心,对预构建的微服务业务集群进行业务注册,得到业务消息列表,并监听所述;
根据预设的事件检索分发策略,在所述事件中心中构建事件发送服务,并根据所述业务消息列表配置所述事件发送服务的调用白名单。
3.如权利要求1所述的系统事件的解耦控制分发方法,其特征在于,所述当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,包括:
判断所述目标微服务的服务类型;
当所述目标微服务为账户登录服务时,拦截所述账户登录服务中登录接口和登出接口的调用,得到账户登录状态,当所述账户登录状态发生改变时,生成基于登录状态变化的事件消息,并利用所述账户登录服务中的网络库调用预构建的事件中心的事件发送服务;
当所述目标微服务为APP生命管理服务时,利用所述APP生命管理服务的代理对象服务调用预构建的事件中心的事件发送服务。
4.如权利要求1至3任意一项所述的系统事件的解耦控制分发方法,其特征在于,所述利用所述事件发送服务将所述事件消息配置为事件对象之后,所述方法还包括:
获取所述事件对象所在的业务消息列表的文件路径,根据所述文件路径配置预构建的消息采集器,及利用预设的文件创建脚本,构建Kafka服务的主题文件;
利用配置好的所述消息采集器,将所述业务消息列表导入所述主题文件中;
利用所述Kafka服务中的Kafka Connect组件,将所述主题文件配置到预构建的流处理工具,并利用所述流处理工具对所述主题文件进行可视化内容统计。
5.如权利要求1所述的系统事件的解耦控制分发方法,其特征在于,所述根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中,包括:
获取所述事件解析结果中的有效关键字,根据所述有效关键字遍历所述业务消息列表,得到目标业务信息;
将所述事件对象分发至所述目标业务信息对应的目标业务服务中。
6.一种系统事件的解耦控制分发装置,其特征在于,所述装置包括:
数据获取模块,用于监听目标微服务的消息队列;
数据传输模块,用于当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,并利用所述事件发送服务将所述事件消息配置为事件对象;
数据分发模块,用于利用所述事件中心,解析所述事件对象,得到事件解析结果,并根据所述事件解析结果,将所述事件对象分发至所述目标微服务中的目标业务服务中。
7.如权利要求6所述的系统事件的解耦控制分发装置,其特征在于,所述从预构建的事件中心中调用事件发送服务之前,所述方法还包括:
获取预构建的事件中心,利用所述事件中心,对预构建的微服务业务集群进行业务注册,得到业务消息列表,并监听所述业务消息列表;
根据预设的事件检索分发策略,在所述事件中心中构建事件发送服务,并根据所述业务消息列表配置所述事件发送服务的调用白名单。
8.如权利要求6所述的系统事件的解耦控制分发装置,其特征在于,所述当所述消息队列中出现事件消息时,从预构建的事件中心中调用事件发送服务,包括:
判断所述目标微服务的服务类型;
当所述目标微服务为账户登录服务时,拦截所述账户登录服务中登录接口和登出接口的调用,得到账户登录状态,当所述账户登录状态发生改变时,生成基于登录状态变化的事件消息,并利用所述账户登录服务中的网络库调用预构建的事件中心的事件发送服务;
当所述目标微服务为APP生命管理服务时,利用所述APP生命管理服务的代理对象服务调用预构建的事件中心的事件发送服务。
9.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至5中任意一项所述的系统事件的解耦控制分发方法。
10.一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至5中任意一项所述的系统事件的解耦控制分发方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310851712.3A CN116939014A (zh) | 2023-07-12 | 2023-07-12 | 系统事件的解耦控制分发方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310851712.3A CN116939014A (zh) | 2023-07-12 | 2023-07-12 | 系统事件的解耦控制分发方法、装置、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116939014A true CN116939014A (zh) | 2023-10-24 |
Family
ID=88390420
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310851712.3A Pending CN116939014A (zh) | 2023-07-12 | 2023-07-12 | 系统事件的解耦控制分发方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116939014A (zh) |
-
2023
- 2023-07-12 CN CN202310851712.3A patent/CN116939014A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110311983B (zh) | 服务请求的处理方法、装置、系统、电子设备及存储介质 | |
CN104636678B (zh) | 一种云计算环境下对终端设备进行管控的方法和系统 | |
CN112867988A (zh) | 由移动设备实现合规设置以遵循配置场景 | |
CN112015663B (zh) | 测试数据录制方法、装置、设备及介质 | |
CN105991412A (zh) | 消息推送方法及装置 | |
CN109039803A (zh) | 一种处理回调通知消息的方法、系统及计算机设备 | |
CN113918357A (zh) | 业务处理方法及装置、存储介质、电子设备 | |
CN111880948A (zh) | 数据刷新方法、装置、电子设备及计算机可读存储介质 | |
CN111897643B (zh) | 线程池配置系统、方法、装置和存储介质 | |
CN107274222A (zh) | 广告投放方法及装置 | |
CN117608825A (zh) | 基于多云管理平台的资源管理方法和相关设备 | |
CN114827161B (zh) | 服务调用请求发送方法、装置、电子设备及可读存储介质 | |
CN111651121A (zh) | 数据逻辑计算方法、装置、电子设备及存储介质 | |
CN101896917B (zh) | 用于移动权限对象的方法和用于管理发布权限对象的权限的方法及其系统 | |
CN116737598B (zh) | 页面调试方法、装置、电子设备和计算机可读介质 | |
CN114125024B (zh) | 音频传输方法、电子设备及可读存储介质 | |
CN116939014A (zh) | 系统事件的解耦控制分发方法、装置、设备及存储介质 | |
CN115022397A (zh) | 接口参数精简方法、装置、电子设备及存储介质 | |
CN113094131A (zh) | 提示资源的显示方法、装置、终端、服务器及存储介质 | |
CN108881344B (zh) | 业务处理方法、装置、存储设备及处理服务器 | |
CN112463616A (zh) | 一种面向Kubernetes容器平台的混沌测试方法和装置 | |
CN115174665B (zh) | 登录状态确定方法、装置、设备及存储介质 | |
CN114389988B (zh) | 基于网络架构的远程过程调用方法、装置、设备及介质 | |
CN115174691B (zh) | 基于页面请求的大数据加载方法、装置、设备及介质 | |
CN110768855A (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 |