CN115277610B - 基于双活环境的消息分流发送方法、装置、设备及介质 - Google Patents
基于双活环境的消息分流发送方法、装置、设备及介质 Download PDFInfo
- Publication number
- CN115277610B CN115277610B CN202210875617.2A CN202210875617A CN115277610B CN 115277610 B CN115277610 B CN 115277610B CN 202210875617 A CN202210875617 A CN 202210875617A CN 115277610 B CN115277610 B CN 115277610B
- Authority
- CN
- China
- Prior art keywords
- message
- client
- area
- preset
- sent
- 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
Links
- 230000009977 dual effect Effects 0.000 title claims abstract description 54
- 238000000034 method Methods 0.000 title claims abstract description 33
- 238000005192 partition Methods 0.000 claims abstract description 106
- 238000009826 distribution Methods 0.000 claims abstract description 91
- 230000001360 synchronised effect Effects 0.000 claims abstract description 41
- 238000000926 separation method Methods 0.000 claims abstract description 38
- 230000005540 biological transmission Effects 0.000 claims abstract description 22
- 230000007246 mechanism Effects 0.000 claims abstract description 16
- 238000003860 storage Methods 0.000 claims abstract description 16
- 238000004806 packaging method and process Methods 0.000 claims description 10
- 238000004590 computer program Methods 0.000 claims description 9
- 238000002716 delivery method Methods 0.000 claims description 2
- 238000000638 solvent extraction Methods 0.000 claims 1
- 238000013473 artificial intelligence Methods 0.000 abstract description 6
- 238000005516 engineering process Methods 0.000 abstract description 5
- 230000006870 function Effects 0.000 description 11
- 238000004891 communication Methods 0.000 description 8
- 238000007726 management method Methods 0.000 description 5
- 238000010586 diagram Methods 0.000 description 4
- 230000000694 effects Effects 0.000 description 4
- 238000004519 manufacturing process Methods 0.000 description 4
- 238000012545 processing Methods 0.000 description 4
- 229940004975 interceptor Drugs 0.000 description 2
- 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
- 238000004458 analytical method Methods 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000000903 blocking effect Effects 0.000 description 1
- 238000007418 data mining 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
- 238000000802 evaporation-induced self-assembly Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Abstract
本发明涉及人工智能技术,揭露了一种基于双活环境的消息分流发送方法,包括:利用生产者生产待发送消息,以及利用分区策略将待发送消息发送至生产者的分区区域;将分区区域分配至客户端,得到客户端分配区域;根据客户端分配区域更新所述客户端的同步状态;在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。此外,本发明还涉及区块链技术,待发送消息可存储于区块链的节点。本发明还提出一种基于双活环境的消息分流发送装置、电子设备以及存储介质。本发明可以提高消息分流发送的灵活性。
Description
技术领域
本发明涉及人工智能技术领域,尤其涉及一种基于双活环境的消息分流发送方法、装置、电子设备及计算机可读存储介质。
背景技术
目前,随着互联网的迅速发展,互联网中会出现各种各样的消息,例如,当用户订阅保险产品信息时,会推送各种各样的保险产品信息,但为了给用户更好的获得消息体验,需要从海量的消息中筛选出用户感兴趣的消息,以进行消息分流。
现有的消息分流方案多为基于版本消息主题方案,消息主题随着版本变化,只要有新版本发布,就会更新消息主题,消息发送时发送到新的消息主题上面,消息消费时会从新的消息主题消费消息。实际应用中,在消息分流发送时可能会丢失消息或重复消费消息,可能导致对消息分流发送过于复杂,从而对进行消息分流发送的灵活性较低。
发明内容
本发明提供一种基于双活环境的消息分流发送方法、装置及计算机可读存储介质,其主要目的在于解决进行消息分流发送的灵活性较低的问题。
为实现上述目的,本发明提供的一种基于双活环境的消息分流发送方法,包括:
利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
将所述分区区域分配至预设的客户端,得到客户端分配区域;
根据所述客户端分配区域更新所述客户端的同步状态;
在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;
利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。
可选地,所述利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域,包括:
利用预设的分布式消息系统将所述待发送消息封装为生产者对象;
获取所述生产者对象中的待发送消息的分区属性;
利用预设的序列化器将所述待发送消息转换为待发送消息字节数组;
根据所述分区策略和所述分区属性将所述待发送消息字节数组发送至所述生产者的分区区域。
可选地,所述将所述分区区域分配至预设的客户端,得到客户端分配区域,包括:
获取所述分区区域的消息主题数量和分区数量;
获取所述客户端的客户端标识;
根据所述消息主题数量、所述分区数量和所述客户端标识确定所述客户端分配区域。
可选地,所述根据所述客户端分配区域更新所述客户端的同步状态,包括:
获取所述客户端的原始分配区域;
确定所述客户端的分配区域与所述原始分配区域的分配区域差异;
将所述客户端标识和所述分配区域差异打包为更新状态包;
根据预设的更新接口和所述更新状态包更新所述客户端的同步状态。
可选地所述在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域,包括:
获取具有所述双活环境机器的配置文件;
将所述同步状态写入至所述配置文件,得到同步配置文件;
根据所述同步配置文件对所述客户端分配区域进行分离,得到同步分离区域;
汇集所述同步分离区域为所述分离区域。
可选地,所述利用预设的消费者拉取所述分离区域中的待发送消息,包括:
获取所述消费者拉取所述分离区域的消息的拉取请求;
根据所述拉取请求调用预设的代理服务器中拉取参数;
利用预设的拉取消息线程服务根据所述拉取参数拉取所述待发送消息。
可选地,所述将所述待发送消息通过预设的消息分发机制进行消息分流发送,包括:
获取所述待发送消息对应的路由信息,以及所述待发送消息的消息发送指令;
将所述路由信息与预设的本地缓存中的路由信息进行信息对比,得到更新路由信息;
根据所述更新路由信息更新代理服务器的地址缓存表;
根据所述消息分发机制、所述消息发送指令及所述地址缓存表进行消息分流发送。
为了解决上述问题,本发明还提供一种基于双活环境的消息分流发送装置,所述装置包括:
消息发送模块,用于利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
分区区域分配模块,用于将所述分区区域分配至预设的客户端,得到客户端分配区域;
客户端状态更新模块,用于根据所述客户端分配区域更新所述客户端的同步状态;
客户端分配区域分离模块,用于在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;
消息分流发送模块,用于利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。
为了解决上述问题,本发明还提供一种电子设备,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行上述所述的基于双活环境的消息分流发送方法。
为了解决上述问题,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质中存储有至少一个计算机程序,所述至少一个计算机程序被电子设备中的处理器执行以实现上述所述的基于双活环境的消息分流发送方法。
本发明实施例能够通过对生产者和消费者进行改造,将消息进行生产时,对所述生产者区域进行分区,让生产端实现消息分流,将生产者的分区重新分配到相应的消费者客户端,同时消费者客户端更新与绑定与分区的同步状态,在具有双活环境的机器分别绑定处理一部分分区,可以实现消息分流,提高进行消息分流发送的灵活性。因此本发明提出的基于双活环境的消息分流发送方法、装置、电子设备及计算机可读存储介质,可以解决进行消息分流发送的灵活性较低的问题。
附图说明
图1为本发明一实施例提供的基于双活环境的消息分流发送方法的流程示意图;
图2为本发明一实施例提供的发送消息的流程示意图;
图3为本发明一实施例提供的更新客户端状态的流程示意图;
图4为本发明一实施例提供的基于双活环境的消息分流发送装置的功能模块图;
图5为本发明一实施例提供的实现所述基于双活环境的消息分流发送方法的电子设备的结构示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本申请实施例提供一种基于双活环境的消息分流发送方法。所述基于双活环境的消息分流发送方法的执行主体包括但不限于服务端、终端等能够被配置为执行本申请实施例提供的该方法的电子设备中的至少一种。换言之,所述基于双活环境的消息分流发送方法可以由安装在终端设备或服务端设备的软件或硬件来执行,所述软件可以是区块链平台。所述服务端包括但不限于:单台服务器、服务器集群、云端服务器或云端服务器集群等。所述服务器可以是独立的服务器,也可以是提供云服务、云数据库、云计算、云函数、云存储、网络服务、云通信、中间件服务、域名服务、安全服务、内容分发网络(ContentDeliveryNetwork,CDN)、以及大数据和人工智能平台等基础云计算服务的云服务器。
参照图1所示,为本发明一实施例提供的基于双活环境的消息分流发送方法的流程示意图。在本实施例中,所述基于双活环境的消息分流发送方法包括:
S1、利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
本发明实施例中,所述生产者负责生产消息,一般由业务系统负责生产消息。一个消息生产者会把业务应用系统里产生的消息发送到代理服务器(Broker Server)。RocketMQ(分布式消息中间件)会提供多种发送方式,比如,同步发送、异步发送、顺序发送、单向发送。同步和异步方式均需要Broker返回确认信息,单向发送不需要。
本发明实施例中,消息的生产是可以指定分区的,在消息生产时,可以通过读取配置项来选择分区,就可以实现生产端的消息分流,其中,每个分区都是一个完全有序的日志,但是分区之间没有全局排序。
本发明实施例中,参图2所示,所述利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域,包括:
S21、利用预设的分布式消息系统将所述待发送消息封装为生产者对象;
S22、获取所述生产者对象中的待发送消息的分区属性;
S23、利用预设的序列化器将所述待发送消息转换为待发送消息字节数组;
S24、根据所述分区策略和所述分区属性将所述待发送消息字节数组发送至所述生产者的分区区域。
详细地,所述分布式消息系统是指kafka,其中,kafka是一个分布式、支持分区、多副本的分布式消息系统,可以实时处理大量数据以满足各种需求场景,比如,kafka经常被用来记录用户的各种活动,如用户在购买保险时浏览保险页面,搜索保险产品、点击购买保险产品等活动,这些活动信息都会被各个服务器发送到kafka中,用于后续做数据离线分析和数据挖掘,其中,可利用预设的封装插件对所述待发送消息进行封装,其中,所述封装插件包括但不限于Javascript封装插件、jQuery封装插件。
具体地,所述生产者对象可以根据所述分区属性决定把消息发送到哪个分区,在一个分区中消息地顺序就是生产者发送消息的顺序,其中,所述生产者对象包含了待发送消息的主题、待发送消息的键值对(key-value),同时还可以指定消息发送的分区区域,所述分区属性可以根据预先指定的分区进行消息分配。
进一步地,所述序列化器(Serializer)会把模型对象转换为字典,其中,利用所述序列化器将所述生产者对象转化为字节数组,才能够将所述生产者对象在网络上传输。
进一步地,可利用预设的线程根据所述分区策略和所述分区属性负责把消息发送至所述生产者的分区区域,其中,所述分区策略是决定生产者将所述待发送消息发送到哪个分区的算法,所述分区策略包括但不限于轮询策略、随机策略,自定义分区策略。
S2、将所述分区区域分配至预设的客户端,得到客户端分配区域;
本发明实施例中,生产者负责生产消息,消费者客户端负责消费消息,代理服务器负责存储消息,其中,所述代理服务器对应一台服务器,每个消费者客户端会从所述代理服务中拉取待发送消息,在所述消费者客户端中根据不同的分区区域得到客户端中的消息分配区域。
本发明实施例中,所述将所述分区区域分配至预设的客户端,得到客户端分配区域,包括:获取所述分区区域的消息主题数量和分区数量;获取所述客户端的客户端标识;根据所述消息主题数量、所述分区数量和所述客户端标识确定所述客户端分配区域。
详细地,可利用KafkaConsumer中的partitionsFor函数查询指定消息主题的元数据信息,其中,所述元数据信息包括分区区域的消息主题数量和分区数量。
具体地,可利用监听器(如Listener)获取所述客户端的客户端标识,其中,服务器通过监听并响应客户端的请求,记录所述客户端的客户端标识,就可以通过监听器获取所述客户端的客户端标识。
示例性地,所述分区区域就是将所述分区区域重新分配至相应的消费者客户端,就是将部分分区区域绑定至一部分消费者客户端,将另外一部分分区区域绑定至另一部分消费者客户端,例如,当前分区区域中有2个消息主题,即T0,T1,每个所述消息主题有3个分区,即T0p0,T0p1,T0p2,T1p0,T1p1,T1p2,根据所述客户端的序号标识,假如客户端的序号标识为客户端1,客户端2,则所述分区区域分配至所述客户端可以根据所述消息主题数量、所述分区数量和所述序号标识对分区区域进行分配,即客户端1(T0p0,T0p2,T1p1),客户端2(T0p1,T1p0,T1p2)。
S3、根据所述客户端分配区域更新所述客户端的同步状态;
本发明实施例中,所述同步状态是指所述分区区域与客户端的绑定关系,例如,客户端1中的消息队列的分区区域为T0p0,T0p2,T1p1,客户端2中的消息队列的分区区域为T0p1,T1p0,T1p2,因此,将消息队列的分区区域与对应的客户端同步,便于使消息分流发送。
本发明实施例中,参图3所示,所述根据所述客户端分配区域更新所述客户端的同步状态,包括:
S31、获取所述客户端的原始分配区域;
S32、确定所述客户端的分配区域与所述原始分配区域的分配区域差异;
S33、将所述客户端标识和所述分配区域差异打包为更新状态包;
S34、根据预设的更新接口和所述更新状态包更新所述客户端的同步状态。
详细地,可利用消费者客户端中的分区查询接口查询待消费的消费主题集合对应的客户端的原始分配区域。
示例性地,当所述客户端的原始分配区域为客户端1(T0p0,T0p2),客户端2(T1p1,T0p1,T1p0,T1p2),当前所述客户端的分配区域为客户端1(T0p0,T0p2,T1p1),客户端2(T0p1,T1p0,T1p2),根据所述客户端的分配区域与客户端的原始分配区域确定所述分配区域差异,即客户端1和客户端2中消息队列中分配区域的差异区域。
具体地,可利用打包工具将所述客户端标识和所述分配区域差异打包为更新状态包,其中,所述打包工具包括但不限于grunt、gulb。
本发明实施例中,可根据所述客户端的同步状态,对所述客户端进行分区分离,得到不同的分区,因此,可以实现消息分流。
S4、在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;
本发明实施例中,所述双活环境是一种高可用保障的方案,双活环境的实现模式是让主备两个数据中心都同时承担用户的业务,此时,主备两个数据中心互为备份,并且进行实时备份。一般来说,主数据中心的负载可能会多一些,保证了当其中一边发生故障时,不至于造成业务无法处理的情况。
本发明实施例中,所述在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域,包括:获取具有所述双活环境机器的配置文件;将所述同步状态写入至所述配置文件,得到同步配置文件;根据所述同步配置文件对所述客户端分配区域进行分离,得到同步分离区域;
汇集所述同步分离区域为所述分离区域。
详细地,可利用具有文件抓取功能的python语句读取所述双活环境机器的配置文件,其中,所述配置文件是列出机器参数值的文本文件,包括文件传输协议,消息分区区域内各节点的端口信息,消息发送线程个数等。
具体地,所述同步状态是指客户端与消息队列分区区域的对应关系,将所述同步状态写入配置文件,客户端会从所述配置文件中读取所述同步状态,以此进行消息主题在双活环境机器下的分区。
示例性地,在一个消息主题中,有4个消息分区,即q1,q2,q3,q4,将q1和q2作为分区区域1,将q3和q4作为分区区域2,客户端1对应的分区区域是分区区域1,客户端2对应的分区区域是分区区域2,根据所述客户端和所述分区区域的对应关系,在所述分区区域1绑定具有双活环境的机器1,在所述分区区域2绑定具有双活环境的机器2,以此实现消息分流。
本发明其中一个实际应用场景,当用户浏览保险产品时,则所述用户会被认为是对保险产品感兴趣,就会把关于保险方面的产品及保险的相关知识消息推送给该用户,当用户浏览金融基金产品时,会认为该用户对基金产品感兴趣,就会把关于基金方面的产品推送给该用户,因此,就会在双活环境下根据分区分域进行消息分流。
S5、利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。
本发明实施例中,所述消费者表示从消息队列中取得消息的客户端应用程序,负责消费消息,一般是后台系统负责异步消费,从用户应用的角度而言提供了两种消费形式,拉取式消费和推动式消费。
本发明实施例中,所述利用预设的消费者拉取所述分离区域中的待发送消息,包括:获取所述消费者拉取所述分离区域的消息的拉取请求;根据所述拉取请求调用预设的代理服务器中拉取参数;利用预设的拉取消息线程服务根据所述拉取参数拉取所述待发送消息。
详细地,可利用预设的拦截器(如Interceptor)获取所述消费者拉取所述分离区域的消息的拉取请求,其中,所述拉取参数包括线程服务的状态、消费者的消费状态、消费的限流状态等。
具体地,所述拉取消息线程服务是指PullMessageService,其中,所述拉取消息线程服务在消息者启动的时候启动,不断从消息阻塞队列中获取拉取消息的请求,然后给代理服务器发送拉取消息的请求,根据所述拉取请求会调用拉取参数,对所述拉取参数进行校验,校验成功会利用所述拉取消息线程将所述待发送消息拉取到消息队列。
本发明实施例中,所述将所述待发送消息通过预设的消息分发机制进行消息分流发送,包括:获取所述待发送消息对应的路由信息,以及所述待发送消息的消息发送指令;将所述路由信息与预设的本地缓存中的路由信息进行信息对比,得到更新路由信息;根据所述更新路由信息更新代理服务器的地址缓存表;根据所述消息分发机制、所述消息发送指令及所述地址缓存表进行消息分流发送。
详细地,可利用tryToFindTopicPublishInfo(查找待发送消息的路由信息)的方式获取所述待发送消息对应的路由信息,其中,所述路由信息包含所述待发送消息的要发送到具体的代理服务器的节点。
具体地,所述消息分发机制是指触发了某个事件时,会把该事件对应的消息分发下去,发送的消息用户可以选择接收或者不接收,例如,用户在进行保险产品咨询时,会有显示是否订阅保险产品信息,当用户选择订阅保险产品信息时,会把该保险产品信息推送给订阅用户。
进一步地,根据所述消息发送指令确定所述待发送消息准备发送的消息指令,根据所述地址缓存表确定所述待发送消息要发送的目的服务器的节点,利用所述消息分发机制将所述待发送消息发送到目的服务器的节点。
本发明实施例能够通过对生产者和消费者进行改造,将消息进行生产时,对所述生产者区域进行分区,让生产端实现消息分流,将生产者的分区重新分配到相应的消费者客户端,同时消费者客户端更新与绑定与分区的同步状态,在具有双活环境的机器分别绑定处理一部分分区,可以实现消息分流,提高进行消息分流发送的灵活性。因此本发明提出的基于双活环境的消息分流发送方法、装置、电子设备及计算机可读存储介质,可以解决进行消息分流发送的灵活性较低的问题。
如图4所示,是本发明一实施例提供的基于双活环境的消息分流发送装置的功能模块图。
本发明所述基于双活环境的消息分流发送装置100可以安装于电子设备中。根据实现的功能,所述基于双活环境的消息分流发送装置100可以包括消息发送模块101、分区区域分配模块102、客户端状态更新模块103、客户端分配区域分离模块104及消息分流发送模块105。本发明所述模块也可以称之为单元,是指一种能够被电子设备处理器所执行,并且能够完成固定功能的一系列计算机程序段,其存储在电子设备的存储器中。
在本实施例中,关于各模块/单元的功能如下:
所述消息发送模块101,用于利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
所述分区区域分配模块102,用于将所述分区区域分配至预设的客户端,得到客户端分配区域;
所述客户端状态更新模块103,用于根据所述客户端分配区域更新所述客户端的同步状态;
所述客户端分配区域分离模块104,用于在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;
所述消息分流发送模块105,用于利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。
详细地,本发明实施例中所述基于双活环境的消息分流发送装置100中所述的各模块在使用时采用与上述图1至图3中所述的基于双活环境的消息分流发送方法一样的技术手段,并能够产生相同的技术效果,这里不再赘述。
如图5所示,是本发明一实施例提供的实现基于双活环境的消息分流发送方法的电子设备的结构示意图。
所述电子设备1可以包括处理器10、存储器11、通信总线12以及通信接口13,还可以包括存储在所述存储器11中并可在所述处理器10上运行的计算机程序,如基于双活环境的消息分流发送程序。
其中,所述处理器10在一些实施例中可以由集成电路组成,例如可以由单个封装的集成电路所组成,也可以是由多个相同功能或不同功能封装的集成电路所组成,包括一个或者多个中央处理器(Central Processing unit,CPU)、微处理器、数字处理芯片、图形处理器及各种控制芯片的组合等。所述处理器10是所述电子设备的控制核心(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用于上述电子设备与其他设备之间的通信,包括网络接口和用户接口。可选地,所述网络接口可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该电子设备与其他电子设备之间建立通信连接。所述用户接口可以是显示器(Display)、输入单元(比如键盘(Keyboard)),可选地,用户接口还可以是标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在电子设备中处理的信息以及用于显示可视化的用户界面。
图中仅示出了具有部件的电子设备,本领域技术人员可以理解的是,图中示出的结构并不构成对所述电子设备的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
例如,尽管未示出,所述电子设备还可以包括给各个部件供电的电源(比如电池),优选地,电源可以通过电源管理装置与所述至少一个处理器10逻辑相连,从而通过电源管理装置实现充电管理、放电管理、以及功耗管理等功能。电源还可以包括一个或一个以上的直流或交流电源、再充电装置、电源故障检测电路、电源转换器或者逆变器、电源状态指示器等任意组件。所述电子设备还可以包括多种传感器、蓝牙模块、Wi-Fi模块等,在此不再赘述。
应该了解,所述实施例仅为说明之用,在专利申请范围上并不受此结构的限制。
所述电子设备1中的所述存储器11存储的基于双活环境的消息分流发送程序是多个指令的组合,在所述处理器10中运行时,可以实现:
利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
将所述分区区域分配至预设的客户端,得到客户端分配区域;
根据所述客户端分配区域更新所述客户端的同步状态;
在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;
利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。
具体地,所述处理器10对上述指令的具体实现方法可参考附图对应实施例中相关步骤的描述,在此不赘述。
进一步地,所述电子设备1集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读存储介质中。所述计算机可读存储介质可以是易失性的,也可以是非易失性的。例如,所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)。
本发明还提供一种计算机可读存储介质,所述可读存储介质存储有计算机程序,所述计算机程序在被电子设备的处理器所执行时,可以实现:
利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
将所述分区区域分配至预设的客户端,得到客户端分配区域;
根据所述客户端分配区域更新所述客户端的同步状态;
在预设的双活环境下根据所述同步状态对所述客户端分配区域进行分离,得到分离区域;
利用预设的消费者拉取所述分离区域中的待发送消息,将所述待发送消息通过预设的消息分发机制进行消息分流发送。
在本发明所提供的几个实施例中,应该理解到,所揭露的设备,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能模块的形式实现。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。
因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化涵括在本发明内。不应将权利要求中的任何附关联图标记视为限制所涉及的权利要求。
本发明所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
本申请实施例可以基于人工智能技术对相关的数据进行获取和处理。其中,人工智能(Artificial Intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用系统。
此外,显然“包括”一词不排除其他单元或步骤,单数不排除复数。系统权利要求中陈述的多个单元或装置也可以由一个单元或装置通过软件或者硬件来实现。第一、第二等词语用来表示名称,而并不表示任何特定的顺序。
最后应说明的是,以上实施例仅用以说明本发明的技术方案而非限制,尽管参照较佳实施例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或等同替换,而不脱离本发明技术方案的精神和范围。
Claims (6)
1.一种基于双活环境的消息分流发送方法,其特征在于,所述方法包括:
利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
将所述分区区域分配至预设的客户端,得到客户端分配区域;
获取所述客户端的原始分配区域,确定所述客户端分配区域与所述原始分配区域的分配区域差异,获取所述客户端的客户端标识,将所述客户端标识和所述分配区域差异打包为更新状态包,根据预设的更新接口和所述更新状态包更新所述客户端的同步状态;
获取具有所述双活环境的配置文件,将所述同步状态写入至所述配置文件,得到同步配置文件,根据所述同步配置文件对所述客户端分配区域进行分离,得到同步分离区域,汇集所述同步分离区域为分离区域;
获取消费者拉取所述分离区域的消息的拉取请求,根据所述拉取请求调用预设的代理服务器中拉取参数,利用预设的拉取消息线程服务根据所述拉取参数拉取所述待发送消息,获取所述待发送消息对应的路由信息,以及所述待发送消息的消息发送指令,将所述路由信息与预设的本地缓存中的路由信息进行信息对比,得到更新路由信息,根据所述更新路由信息更新代理服务器的地址缓存表,根据消息分发机制、所述消息发送指令及所述地址缓存表进行消息分流发送。
2.如权利要求1所述的基于双活环境的消息分流发送方法,其特征在于,所述利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域,包括:
利用预设的分布式消息系统将所述待发送消息封装为生产者对象;
获取所述生产者对象中的待发送消息的分区属性;
利用预设的序列化器将所述待发送消息转换为待发送消息字节数组;
根据所述分区策略和所述分区属性将所述待发送消息字节数组发送至所述生产者的分区区域。
3.如权利要求1所述的基于双活环境的消息分流发送方法,其特征在于,所述将所述分区区域分配至预设的客户端,得到客户端分配区域,包括:
获取所述分区区域的消息主题数量和分区数量;
获取所述客户端的客户端标识;
根据所述消息主题数量、所述分区数量和所述客户端标识确定所述客户端分配区域。
4.一种基于双活环境的消息分流发送装置,其特征在于,所述装置包括:
消息发送模块,用于利用预设的生产者生产待发送消息,以及利用预设的分区策略将所述待发送消息发送至所述生产者的分区区域;
分区区域分配模块,用于将所述分区区域分配至预设的客户端,得到客户端分配区域;
客户端状态更新模块,用于获取所述客户端的原始分配区域,确定所述客户端分配区域与所述原始分配区域的分配区域差异,获取所述客户端的客户端标识,将所述客户端标识和所述分配区域差异打包为更新状态包,根据预设的更新接口和所述更新状态包更新所述客户端的同步状态;
客户端分配区域分离模块,用于获取具有所述双活环境的配置文件,将所述同步状态写入至所述配置文件,得到同步配置文件,根据所述同步配置文件对所述客户端分配区域进行分离,得到同步分离区域,汇集所述同步分离区域为分离区域;
消息分流发送模块,用于获取消费者拉取所述分离区域的消息的拉取请求,根据所述拉取请求调用预设的代理服务器中拉取参数,利用预设的拉取消息线程服务根据所述拉取参数拉取所述待发送消息,获取所述待发送消息对应的路由信息,以及所述待发送消息的消息发送指令,将所述路由信息与预设的本地缓存中的路由信息进行信息对比,得到更新路由信息,根据所述更新路由信息更新代理服务器的地址缓存表,根据消息分发机制、所述消息发送指令及所述地址缓存表进行消息分流发送。
5.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至3中任意一项所述的基于双活环境的消息分流发送方法。
6.一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至3中任意一项所述的基于双活环境的消息分流发送方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210875617.2A CN115277610B (zh) | 2022-07-25 | 基于双活环境的消息分流发送方法、装置、设备及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210875617.2A CN115277610B (zh) | 2022-07-25 | 基于双活环境的消息分流发送方法、装置、设备及介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115277610A CN115277610A (zh) | 2022-11-01 |
CN115277610B true CN115277610B (zh) | 2024-06-04 |
Family
ID=
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106095589A (zh) * | 2016-06-30 | 2016-11-09 | 浪潮软件集团有限公司 | 一种分配分区的方法、装置及系统 |
CN109901948A (zh) * | 2019-02-18 | 2019-06-18 | 国家计算机网络与信息安全管理中心 | 无共享数据库集群异地双活容灾系统 |
CN113132678A (zh) * | 2019-12-31 | 2021-07-16 | 深圳云天励飞技术有限公司 | 一种数据传输方法、装置、电子设备及存储介质 |
CN113157701A (zh) * | 2021-04-27 | 2021-07-23 | 中国工商银行股份有限公司 | 一种oracle数据库的双活机制部署方法及装置 |
CN114610817A (zh) * | 2022-05-12 | 2022-06-10 | 恒生电子股份有限公司 | 数据同步方法、装置、多活系统、电子设备及存储介质 |
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106095589A (zh) * | 2016-06-30 | 2016-11-09 | 浪潮软件集团有限公司 | 一种分配分区的方法、装置及系统 |
CN109901948A (zh) * | 2019-02-18 | 2019-06-18 | 国家计算机网络与信息安全管理中心 | 无共享数据库集群异地双活容灾系统 |
CN113132678A (zh) * | 2019-12-31 | 2021-07-16 | 深圳云天励飞技术有限公司 | 一种数据传输方法、装置、电子设备及存储介质 |
CN113157701A (zh) * | 2021-04-27 | 2021-07-23 | 中国工商银行股份有限公司 | 一种oracle数据库的双活机制部署方法及装置 |
CN114610817A (zh) * | 2022-05-12 | 2022-06-10 | 恒生电子股份有限公司 | 数据同步方法、装置、多活系统、电子设备及存储介质 |
Non-Patent Citations (1)
Title |
---|
王春波著.《高效使用Greenplum入门-进阶与数据中台》.机械工业出版社,2021,第235-238页. * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111736775B (zh) | 多源存储方法、装置、计算机系统及存储介质 | |
TWI549080B (zh) | The method, system and device for sending information of category information | |
CN109189841B (zh) | 一种多数据源访问方法及系统 | |
US20050267863A1 (en) | Access to content addressable data over a network | |
EP2044749B1 (en) | Dispatching request fragments from a response aggregating surrogate | |
CN101997823A (zh) | 一种分布式文件系统及其数据访问方法 | |
US9589153B2 (en) | Securing integrity and consistency of a cloud storage service with efficient client operations | |
CN110784498B (zh) | 一种个性化数据容灾方法及装置 | |
JP2009282807A (ja) | メッセージ紐付け処理装置、方法及びプログラム | |
CN110825479A (zh) | 页面处理方法、装置、终端设备、服务器和存储介质 | |
CN109783151B (zh) | 规则变更的方法和装置 | |
CN110347651A (zh) | 基于云存储的数据同步方法、装置、设备及存储介质 | |
CN113220795B (zh) | 基于分布式存储的数据处理方法、装置、设备以及介质 | |
CN109254854A (zh) | 异步调用方法、计算机装置及存储介质 | |
EP4207688A1 (en) | Asynchronous bookkeeping method and apparatus for blockchain, medium, and electronic device | |
EP4020270A1 (en) | Attestation support for elastic cloud computing environments | |
CN111339057A (zh) | 减少回源请求的方法、装置及计算机可读存储介质 | |
CN114610504A (zh) | 消息处理方法、装置、电子设备及存储介质 | |
CN111444148B (zh) | 基于MapReduce的数据传输方法和装置 | |
US20130138782A1 (en) | Tiered xml services in a content management system | |
US20190258746A1 (en) | Using observable data object to unmarshal graph data | |
CN115277610B (zh) | 基于双活环境的消息分流发送方法、装置、设备及介质 | |
CN110325980A (zh) | 用于数据库绑定型应用的用户界面后端集群的扩展技术 | |
CN115277610A (zh) | 基于双活环境的消息分流发送方法、装置、设备及介质 | |
CN112187916A (zh) | 一种跨系统的数据同步方法与装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant |