CN113783666A - 一种处理业务的方法和装置 - Google Patents
一种处理业务的方法和装置 Download PDFInfo
- Publication number
- CN113783666A CN113783666A CN202011357664.5A CN202011357664A CN113783666A CN 113783666 A CN113783666 A CN 113783666A CN 202011357664 A CN202011357664 A CN 202011357664A CN 113783666 A CN113783666 A CN 113783666A
- Authority
- CN
- China
- Prior art keywords
- service
- message
- result data
- downstream
- service message
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 48
- 238000012545 processing Methods 0.000 title claims abstract description 46
- 238000011144 upstream manufacturing Methods 0.000 claims abstract description 54
- 230000002159 abnormal effect Effects 0.000 claims abstract description 26
- 238000004590 computer program Methods 0.000 claims description 11
- 230000005540 biological transmission Effects 0.000 claims description 8
- 239000000126 substance Substances 0.000 claims description 3
- 238000010586 diagram Methods 0.000 description 9
- 238000004891 communication Methods 0.000 description 6
- 230000006870 function Effects 0.000 description 6
- 230000008569 process Effects 0.000 description 5
- 230000003287 optical effect Effects 0.000 description 4
- 230000005856 abnormality Effects 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000001934 delay Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 239000000835 fiber Substances 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 230000002411 adverse Effects 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000005096 rolling process Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/18—Automatic repetition systems, e.g. Van Duuren systems
- H04L1/1867—Arrangements specially adapted for the transmitter end
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/1607—Details of the supervisory signal
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/18—Automatic repetition systems, e.g. Van Duuren systems
- H04L1/1809—Selective-repeat protocols
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明公开了一种处理业务的方法和装置,涉及计算机技术领域。该方法的一具体实施方式包括:能够在成功执行本地业务操作之后,发送业务消息给下游单元,并获取所述业务消息的结果数据;当结果数据异常时,保存业务消息到重试消息集合中,针对结果数据的异常原因,利用不同线程根据重试策略发送所述业务消息直到获得成功的结果数据;通过对业务消息的存储和重试操作,克服了上下游业务单元之间数据不一致问题,即上游业务单元因网络等原因导致返回的结果数据异常和数据回退,但是下游业务单元成功接收业务消息并执行了业务和数据写入操作。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种处理业务的方法和装置。
背景技术
随着互联网应用系统的复杂度的提高,分布式系统在互联网应用中得到广泛应用,在分布式系统中,关联于各种业务的数据库在任何业务对应的操作下数据都应该是一致的。
但是,现有技术中至少存在如下问题:
在分布式系统中,一个上游业务单元发送给下游业务单元的消息(请求)得到的响应信息为发送失败,发送失败的原因可能为网络延迟导致的超时,该业务单元因为收到失败的响应信息因此对本地数据库执行回退操作;同时下游业务单元延迟收到了消息,并根据消息执行了下游本地业务操作,包括完成对数据库的写操作;由此可见,上述流程造成了上游业务单元与下游业务单元中关联的数据库中的数据不一致的问题。
发明内容
有鉴于此,本发明实施例提供一种处理业务的方法和装置,能够在成功执行本地业务操作之后,发送业务消息给下游单元,并获取所述业务消息的结果数据;当结果数据异常时,保存业务消息到重试消息集合中,针对结果数据的异常原因,利用不同线程根据重试策略发送所述业务消息直到获得成功的结果数据;通过对业务消息的存储和重试操作,克服了上下游业务单元之间数据不一致问题,即上游业务单元因网络等原因导致返回的结果数据异常和数据回退,但是下游业务单元成功接收业务消息并执行了业务和数据写入操作。
为实现上述目的,根据本发明实施例的一个方面,提供了一种处理业务的方法,其特征在于,包括:接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息;执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
可选地,所述处理业务的方法,其特征在于,
存储所述业务消息和所述结果数据,并向所述下游业务单元重新发送所述业务消息,直到所述下游业务单元返回指示为成功的结果数据,包括:存储所述业务消息以及所述结果数据到重试消息集合中;从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,直到所述下游业务单元返回指示为成功的结果数据;在所述重试消息集合中标记所述结果数据为成功。
可选地,所述处理业务的方法,其特征在于,
当所述业务消息发送失败时,标记所述业务消息对应的发送结果为失败,并存储所述业务消息和所述发送结果到所述重试消息集合中。
可选地,所述处理业务的方法,其特征在于,
从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,包括:从所述重试消息集合中获取所述业务消息,当所述业务消息对应的所述结果数据指示为异常时,利用第一线程,根据设定重试策略,重新发送所述业务消息、接收所述下游业务单元返回的结果数据,并更新重试业务消息集合中的所述业务消息对应的所述结果数据。
可选地,所述处理业务的方法,其特征在于,
从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,还包括:从所述重试消息集合中获取一个或多个所述业务消息,当所述业务消息对应的发送结果指示为失败时,利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述发送结果。
可选地,所述处理业务的方法,其特征在于,
存储所述业务消息和所述发送结果到所述重试消息集合中,还包括:利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。
可选地,所述处理业务的方法,其特征在于,
在一个时间点,运行所述第一线程、所述第二线程、所述第三线程中任意一个获得线程锁的线程。
为实现上述目的,根据本发明实施例的第二方面,提供了一种处理业务的装置,其特征在于,包括:业务请求处理模块、业务消息发送模块和业务消息容错模块;其中,
所述业务请求处理模块,用于接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息;
所述业务消息发送模块,用于执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;
所述业务消息容错模块,用于接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
可选地,所述处理业务的装置,其特征在于,
存储所述业务消息和所述结果数据,并向所述下游业务单元重新发送所述业务消息,直到所述下游业务单元返回指示为成功的结果数据,包括:存储所述业务消息以及所述结果数据到重试消息集合中;从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,直到所述下游业务单元返回指示为成功的结果数据;在所述重试消息集合中标记所述结果数据为成功。
可选地,所述处理业务的装置,其特征在于,
当所述业务消息发送失败时,标记所述业务消息对应的发送结果为失败,并存储所述业务消息和所述发送结果到所述重试消息集合中。
可选地,所述处理业务的装置,其特征在于,
从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,包括:从所述重试消息集合中获取所述业务消息,当所述业务消息对应的所述结果数据指示为异常时,利用第一线程,根据设定重试策略,重新发送所述业务消息、接收所述下游业务单元返回的结果数据,并更新重试业务消息集合中的所述业务消息对应的所述结果数据。
可选地,所述处理业务的装置,其特征在于,
从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,还包括:从所述重试消息集合中获取一个或多个所述业务消息,当所述业务消息对应的发送结果指示为失败时,利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述发送结果。
可选地,所述处理业务的装置,其特征在于,
存储所述业务消息和所述发送结果到所述重试消息集合中,还包括:利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。
可选地,所述处理业务的装置,其特征在于,
在一个时间点,运行所述第一线程、所述第二线程、所述第三线程中任意一个获得线程锁的线程。
为实现上述目的,根据本发明实施例的第三方面,提供了一种处理业务的电子设备,其特征在于,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如上述处理业务的方法中任一所述的方法。
为实现上述目的,根据本发明实施例的第四方面,提供了一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如上述处理业务的方法中任一所述的方法。
上述发明中的一个实施例具有如下优点或有益效果:能够在成功执行本地业务操作之后,发送业务消息给下游单元,并获取所述业务消息的结果数据;当结果数据异常时,保存业务消息到重试消息集合中,针对结果数据的异常原因,利用不同线程根据重试策略发送所述业务消息直到获得成功的结果数据;通过对业务消息的存储和重试操作,克服了上下游业务单元之间数据不一致问题,即上游业务单元因网络等原因导致返回的结果数据异常和数据回退,但是下游业务单元成功接收业务消息并执行了业务和数据写入操作。
上述的非惯用的可选方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是本发明一个实施例提供的一种处理业务的方法的流程示意图;
图2是本发明一个实施例提供的一种处理业务的流程示意图;
图3是本发明一个实施例提供的一种业务消息重试的流程示意图;
图4是本发明一个实施例提供的一种处理业务的装置的结构示意图;
图5是本发明实施例可以应用于其中的示例性系统架构图;
图6是适于用来实现本发明实施例的终端设备或服务器的计算机系统的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
如图1所示,本发明实施例提供了一种处理业务的方法,该方法可以包括以下步骤:
步骤S101:接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息。
具体地,在分布式系统中,一个或多个上游业务单元接收客户端或者服务端发送的一个或多个业务请求,确定业务请求对应的上游业务操作和业务消息;例如:业务请求为购买商品的下单请求,则对应的上游业务操作可以为:在本地生成订单并保存订单数据到数据库(即所述业务操作包含处理本地业务的操作),进一步地发送订单对应的库存消息(即为业务消息)给下游业务单元(例如:库存业务单元);即,所述业务消息指示所述下游业务单元(例如:库存业务单元)所执行的业务操作(例如:根据订单的物品数量修改库存数据);优选地,业务单元与其对应的一个或多个下游业务单元可以归属于分布式系统中不同的物理设备。本发明对业务请求、上游业务操作(即业务单元本地的业务操作)、业务消息的具体内容和格式不做限定;可以理解的是,本发明所提及的上游业务单元和下游业务单元是指业务消息发送的方向为从上游业务单元发送至下游业务单元,与业务单元在系统结构中的物理位置无关,本发明对上游业务单元的数量、所关联的下游业务单元的数量和形式、以及各个业务单元组成的系统架构形式不做限定。
步骤S102:执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作。
具体地,上游业务单元根据接收的业务请求执行上游业务操作,例如:业务请求为购买商品的下单请求,则对应的上游业务操作可以是在本地生成订单并保存订单数据到数据库;进一步地,执行上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;例如:在上游业务单元的生成订单成功的情况下,发送修改库存的业务消息给下游业务单元,以使执行修改库存业务操作的下游业务单元相应地执行修改库存的下游业务操作;即,所述业务消息指示所述下游业务单元所执行的业务操作;其中,下游服务单元为接收业务消息的业务单元,并根据接收到的业务消息对应地执行本地的业务操作;业务单元发送业务消息所使用的协议可以是RPC(Remote Procedure Call,远程过程调用)、HTTP(HyperText Transfer Protocol超文本传输协议)、FTP(File Transfer Protocol,文件传输协议)等,优选地,通过服务器(例如:消息队列服务器、文件服务器等)传输业务消息以及结果数据,本发明对业务消息所使用的传输协议和传输方式不做限定;在本发明的一个实施例中,可以利用投递线程发送一个或多个业务消息。
步骤S103:接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
具体地,接收下游业务单元发送返回的对应于所述业务消息的结果数据;所述结果数据可以是正常或者异常;可以理解的是,由于业务单元所在的物理设备故障或者网络异常,可以造成发送结果指示为失败,即,当所述业务消息发送失败时,标记所述业务消息对应的发送结果为失败,并存储对应的所述业务消息和所述发送结果到所述重试消息集合中;进一步地,在发送结果指示为成功的情况下,接收下游业务单元返回的结果数据,结果数据可以是正常、或者异常(其中异常可能为网络超时、目标不可达等原因)。进一步地,存储所述业务消息和所述结果数据,并向所述下游业务单元重新发送所述业务消息,直到所述下游业务单元返回指示为成功的结果数据,包括:存储所述业务消息以及所述结果数据到重试消息集合中;从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,直到所述下游业务单元返回指示为成功的结果数据;在所述重试消息集合中标记所述结果数据为成功。具体地,当结果数据指示为异常时,为保持本地业务的一致性,现有技术通常会回退业务操作至未执行的状态,包括回退已经修改的数据库中的记录;本发明所采用的方法为将结果数据指示为异常对应的业务消息以及结果数据存储于重试消息集合中,并根据重试策略,重新发送一次或多次所述业务消息,直到下游业务单元返回指示为成功的结果数据;通过该方法,在多次重新发送业务消息直到得到指示为成功的数据结果,保证了本地的业务操作与发送的业务消息均为成功,从而客服了因为网络超时等原因指示为数据结果异常,但是下游业务单元延迟接收到业务消息并执行了业务操作,从而造成的数据不一致性。
进一步地,可以利用步骤S102所描述的投递线程存储结果数据指示为异常的业务消息和对应的结果数据到重试消息集合;重试消息集合可以是数据库的数据表,文本文件等,也可以是消息队列等形式;本发明对重试消息集合的具体格式和具体形式不做限定。可以理解的是,从重新消息集合中获取各个业务消息,根据设定策略,重新发送,并将得到的结果数据进行对应的更新。
进一步地,从所述重试业务消息集合中获取所述业务消息,当所述业务消息对应的所述结果数据指示为异常时,利用第一线程,根据设定重试策略,重新发送所述业务消息、接收所述下游业务单元的结果数据,并更新重试业务消息集合中的所述业务消息对应的所述结果数据。其中,第一线程为重试线程,基于该线程锁执行的操作为根据设定重试策略,重新发送所述业务消息,并更新所述业务消息对应的所述结果数据。其中,设定重试策略可以包括:设定重试次数的最大数值;设定各个重试之间的时间间隔等;结果数据为下游业务单元所返回;可以理解的是,下游业务单元在接收到多个业务消息时,可以利用幂等性处理所接受的多个消息。其中,幂等性就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次接收请求而产生不良影响。
进一步地,从所述重试消息集合中获取一个或多个所述业务消息,当所述业务消息对应的发送结果指示为失败时,利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述发送结果。其中,第二线程为处理发送结果指示为失败(例如:未发送)的补充线程。
进一步地,利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。其中,第三线程为清除线程,用于删除重试消息集合中失效的业务消息:例如:保存时长超过设定时长阈值(例如:24小时)的业务消息或/和业务消息经过重试已经获取指示为成功的结果数据,可以理解的是,通过清除失效的业务消息以及结果数据,使重试消息集合具有实时性并且不包含冗余数据。提高访问数据的效率。
再进一步地,在一个时间点,运行所述第一线程、所述第二线程、所述第三线程中任意一个获得线程锁的线程。可以理解的是,上述三个线程在独立运行中,利用线程锁使得在一个时间点,只有一个线程在运行,以保持业务或数据的一致性,并使得业务或数据不存在访问冲突。
如图2所示,本发明实施例提供了一种处理业务的方法,该方法可以包括以下步骤:
下面以订单业务所包含的下单业务和库存业务为例,说明本发明的一个实施例,示例流程如下:
步骤S201:上游业务单元1执行业务操作。
具体地,假设上游业务单元1接收下单的业务请求,分别确定所述业务请求对应的上游业务操作和业务消息,其中,上游业务操作包括执行下单的业务逻辑以及将订单数据写入数据库1等,并确定发给下游业务单元的业务消息(例如:通知下游业务单元进行库存的下游业务操作);即,接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息。
步骤S202:在上游业务操作指示为成功后,发送业务消息给下游业务单元,所述业务消息指示所述下游业务单元所执行的下游业务操作。
具体地,如图2所示,上游业务单元1的下游业务单元为业务单元2,其中,业务消息指示所述下游业务单元所执行的下游业务操作;业务单元1的下游业务单元也为业务单元2(例如:用于处理库存业务的业务单元,包括读写库存数据库的数据),上游业务单元(一个或多个)与下游业务单元(一个或多个)的关联性由系统架构设计和业务场景而设定。即,执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;
步骤S203:结果数据指示为异常时,存储对应的所述业务消息和所述结果数据到重试消息集合中。
具体地,上游业务单元1判断对应于业务消息的结果数据指示为异常时,利用投递线程,存储对应的所述业务消息和所述结果数据到重试消息集合中;关于结果数据和重试消息集合的描述与步骤S103的描述一致,在此不再赘述。
步骤S204:重新发送业务消息,并获取结果数据。
具体地,从重试消息集合中,获取业务消息,重新发送或获取结果数据,更新重试消息集合中的结果数据。
步骤S203-步骤S204的描述即为:接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。包括:在重新发送业务消息之后,更新重试消息集合中的结果数据。
如图3所示,本发明实施例提供了一种业务消息重试的方法,该方法可以包括以下步骤;
具体地,通过循环步骤S301-步骤S308的步骤遍历重试消息集合中的各个业务消息。
步骤S301:获取重试消息集合的数据,包含业务消息和其结果数据。
步骤S302:判断是否为结果数据指示为异常。
具体地,若是,执行步骤S305。
步骤S303:判断是否为发送结果指示为失败
具体地,若是,执行步骤S306。
步骤S304:判断结果数据是否指示为失效。
具体地,若是,执行步骤S307。
步骤S305:利用第一线程,根据设定重试策略,重新发送所述业务消息,并更新所述业务消息对应的所述结果数据。
步骤S306:利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述结果数据。
步骤S307:利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。
步骤S308:判断是否达到重试策略的重试阈值。
具体地,若是,执行步骤S309;否则执行步骤S301。
步骤S309:标记结果数据为失败。
具体地,经过设定重试策略,对应业务消息的结果数据仍为失败时,则回退本地业务(包括本地的数据读写),本步骤的操作为现有技术所使用的方法,本发明对此方法不做进一步地探讨。
步骤S310:获取线程锁。
具体地,在一个时间点,运行所述第一线程、所述第二线程、所述第三线程中任意一个获得线程锁的线程。
进一步地,上述步骤S301、步骤S302、步骤S305、步骤S308、步骤S309的描述即为:从所述重试消息集合中获取所述业务消息,当所述业务消息对应的所述结果数据指示为异常时,利用第一线程,根据设定重试策略,重新发送所述业务消息、接收所述下游业务单元返回的结果数据,并更新重试业务消息集合中的所述业务消息对应的所述结果数据
上述步骤S301、步骤S303、步骤S306的描述即为:从所述重试消息集合中获取一个或多个所述业务消息,当所述业务消息对应的发送结果指示为失败时,利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述发送结果。
上述步骤S301、步骤S304、步骤S307的描述即为:利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。
如图4所示,本发明实施例提供了一种处理业务的装置400,包括:业务请求处理模块401、业务消息发送模块402和业务消息容错模块493;其中,
所述业务请求处理模块401,所述业务请求处理模块,用于接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息;
所述业务消息发送模块402,用于执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;
所述业务消息容错模块403,用于接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
可选地,所述业务消息容错模块403,还用于存储所述业务消息和所述结果数据,并向所述下游业务单元重新发送所述业务消息,直到所述下游业务单元返回指示为成功的结果数据,包括:存储所述业务消息以及所述结果数据到重试消息集合中;从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,直到所述下游业务单元返回指示为成功的结果数据;在所述重试消息集合中标记所述结果数据为成功。
可选地,所述业务消息容错模块403,还用于当所述业务消息发送失败时,标记所述业务消息对应的发送结果为失败,并存储所述业务消息和所述发送结果到所述重试消息集合中。
可选地,所述业务消息容错模块403,还用于从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,包括:从所述重试消息集合中获取所述业务消息,当所述业务消息对应的所述结果数据指示为异常时,利用第一线程,根据设定重试策略,重新发送所述业务消息、接收所述下游业务单元返回的结果数据,并更新重试业务消息集合中的所述业务消息对应的所述结果数据。
可选地,所述业务消息容错模块403,还用于从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,还包括::从所述重试消息集合中获取一个或多个所述业务消息,当所述业务消息对应的发送结果指示为失败时,利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述发送结果。
可选地,所述业务消息容错模块403,还用于存储所述业务消息和所述发送结果到所述重试消息集合中,还包括:利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。
可选地,所述业务消息容错模块403,还用于在一个时间点,运行所述第一线程、所述第二线程、所述第三线程中任意一个获得线程锁的线程。
本发明实施例还提供了一种处理业务的电子设备,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现上述任一实施例提供的方法。
本发明实施例还提供了一种计算机可读介质,其上存储有计算机程序,所述程序被处理器执行时实现上述任一实施例提供的方法。
图5示出了可以应用本发明实施例的处理业务的方法或处理业务的装置的示例性系统架构500。
如图5所示,系统架构500可以包括终端设备501、502、503,网络504和服务器505。网络504用以在终端设备501、502、503和服务器505之间提供通信链路的介质。网络504可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备501、502、503通过网络504与服务器505交互,以接收或发送消息等。终端设备501、502、503上可以安装有各种客户端应用,例如电子商城客户端应用、网页浏览器应用、搜索类应用、即时通信工具和邮箱客户端等。
终端设备501、502、503可以是具有显示屏并且支持各种客户端应用的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器505可以是提供各种服务的服务器,例如对用户利用终端设备501、502、503所使用的客户端应用提供支持的后台管理服务器。后台管理服务器可以对接收到的业务请求进行处理,并将业务返回结果数据反馈给终端设备。
需要说明的是,本发明实施例所提供的处理业务的方法一般由终端设备501、502、503或服务器505执行,相应地,处理业务的装置一般设置于服务器505中。
应该理解,图5中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
下面参考图6,其示出了适于用来实现本发明实施例的终端设备的计算机系统600的结构示意图。图6示出的终端设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图6所示,计算机系统600包括中央处理单元(CPU)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有系统600操作所需的各种程序和数据。CPU 601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入存储部分608。
特别地,根据本发明公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元(CPU)601执行时,执行本发明的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的模块和/或单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的模块和/或单元也可以设置在处理器中,例如,可以描述为:一种处理器包括业务请求处理模块、业务消息发送模块和业务消息容错模块。其中,这些模块的名称在某种情况下并不构成对该模块本身的限定,例如,业务消息容错模块还可以被描述为“从重试消息集合中,获取各个业务消息,并重新发送一次或多次业务消息的模块”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该设备包括:接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息;执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
由此可见,本发明的一个实施例能够在成功执行本地业务操作之后,发送业务消息给下游单元,并获取所述业务消息的结果数据;当结果数据异常时,保存业务消息到重试消息集合中,针对结果数据的异常原因,利用不同线程根据重试策略发送所述业务消息直到获得成功的结果数据;通过对业务消息的存储和重试操作,克服了上下游业务单元之间数据不一致问题,即上游业务单元因网络等原因导致返回的结果数据异常和数据回退,但是下游业务单元成功接收业务消息并执行了业务和数据写入操作。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。
Claims (10)
1.一种处理业务的方法,其特征在于,包括:
接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息;
执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;
接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
2.根据权利要求1所述的方法,其特征在于,
存储所述业务消息和所述结果数据,并向所述下游业务单元重新发送所述业务消息,直到所述下游业务单元返回指示为成功的结果数据,包括:
存储所述业务消息以及所述结果数据到重试消息集合中;从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,直到所述下游业务单元返回指示为成功的结果数据;在所述重试消息集合中标记所述结果数据为成功。
3.根据权利要求2所述的方法,其特征在于,还包括:
当所述业务消息发送失败时,标记所述业务消息对应的发送结果为失败,并存储所述业务消息和所述发送结果到所述重试消息集合中。
4.根据权利要求2所述的方法,其特征在于,
从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,包括:
从所述重试消息集合中获取所述业务消息,当所述业务消息对应的所述结果数据指示为异常时,利用第一线程,根据设定重试策略,重新发送所述业务消息、接收所述下游业务单元返回的结果数据,并更新重试业务消息集合中的所述业务消息对应的所述结果数据。
5.根据权利要求3所述的方法,其特征在于,
从所述重试消息集合中获取并重新发送所述业务消息给所述下游业务单元,还包括:
从所述重试消息集合中获取一个或多个所述业务消息,当所述业务消息对应的发送结果指示为失败时,利用第二线程,重新发送所述业务消息,并更新所述业务消息对应的所述发送结果。
6.根据权利要求2或3所述的方法,其特征在于,
存储所述业务消息和所述发送结果到所述重试消息集合中,还包括:
利用第三线程清除所述重新消息集合中失效的业务消息,所述失效的业务消息包括指示为成功的所述结果数据所对应的所述业务消息,和/或在重新消息集合中保存时长超过设定时长阈值的所述业务消息。
7.根据权利要求3-5任一所述的方法,其特征在于,
在一个时间点,运行所述第一线程、所述第二线程、所述第三线程中任意一个获得线程锁的线程。
8.一种处理业务的装置,其特征在于,包括:业务请求处理模块、业务消息发送模块和业务消息容错模块;其中,
所述业务请求处理模块,用于接收一个或多个业务请求,分别确定所述业务请求对应的上游业务操作和业务消息;
所述业务消息发送模块,用于执行所述上游业务操作,在所述上游业务操作指示为成功的情况下,发送所述业务消息给下游业务单元,以使所述下游业务单元根据所述业务消息执行下游业务操作;其中,所述业务消息指示所述下游业务单元所执行的下游业务操作;
所述业务消息容错模块,用于接收所述下游业务单元发送返回的对应于所述业务消息的结果数据;当所述结果数据指示为异常时,存储对应的所述业务消息和所述结果数据,并向所述下游业务单元重新发送一次或者多次所述业务消息,直到所述下游业务单元返回指示为成功的结果数据。
9.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-7中任一所述的方法。
10.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1-7中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011357664.5A CN113783666B (zh) | 2020-11-27 | 一种处理业务的方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011357664.5A CN113783666B (zh) | 2020-11-27 | 一种处理业务的方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113783666A true CN113783666A (zh) | 2021-12-10 |
CN113783666B CN113783666B (zh) | 2024-07-16 |
Family
ID=
Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007109986A1 (fr) * | 2006-03-27 | 2007-10-04 | Alibaba Group Holding Limited | Procédé et dispositif fiables de notification de messages entre systèmes |
CN101166114A (zh) * | 2006-10-17 | 2008-04-23 | 中兴通讯股份有限公司 | 多媒体广播组播服务会话开始的异常处理方法 |
CN106411684A (zh) * | 2015-07-30 | 2017-02-15 | 中兴通讯股份有限公司 | 消息处理方法及装置 |
CN107908494A (zh) * | 2017-11-10 | 2018-04-13 | 泰康保险集团股份有限公司 | 异常事件的处理方法、装置、电子设备及存储介质 |
CN108153598A (zh) * | 2017-12-25 | 2018-06-12 | 东软集团股份有限公司 | 基于微服务架构的数据一致性方法以及装置 |
CN108647105A (zh) * | 2018-05-22 | 2018-10-12 | 阿里巴巴集团控股有限公司 | 系统切换过程中的幂等控制方法、装置及系统 |
CN108965164A (zh) * | 2017-05-17 | 2018-12-07 | 北京京东尚科信息技术有限公司 | 基于消息队列的业务请求重传方法、装置及可读存储介质 |
CN109241186A (zh) * | 2018-08-29 | 2019-01-18 | 深圳市小牛在线互联网信息咨询有限公司 | 分布式事务的管理方法、系统、计算机设备及存储介质 |
CN109710625A (zh) * | 2018-12-20 | 2019-05-03 | 中科曙光国际信息产业有限公司 | 基于可靠消息的分布式一致性的实现方法 |
CN111510349A (zh) * | 2020-04-09 | 2020-08-07 | 上海东普信息科技有限公司 | 业务异常检测和告警方法、装置、设备及存储介质 |
CN111899105A (zh) * | 2020-08-04 | 2020-11-06 | 深圳乐信软件技术有限公司 | 系统异常处理方法、装置、计算机设备及存储介质 |
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007109986A1 (fr) * | 2006-03-27 | 2007-10-04 | Alibaba Group Holding Limited | Procédé et dispositif fiables de notification de messages entre systèmes |
CN101166114A (zh) * | 2006-10-17 | 2008-04-23 | 中兴通讯股份有限公司 | 多媒体广播组播服务会话开始的异常处理方法 |
CN106411684A (zh) * | 2015-07-30 | 2017-02-15 | 中兴通讯股份有限公司 | 消息处理方法及装置 |
CN108965164A (zh) * | 2017-05-17 | 2018-12-07 | 北京京东尚科信息技术有限公司 | 基于消息队列的业务请求重传方法、装置及可读存储介质 |
CN107908494A (zh) * | 2017-11-10 | 2018-04-13 | 泰康保险集团股份有限公司 | 异常事件的处理方法、装置、电子设备及存储介质 |
CN108153598A (zh) * | 2017-12-25 | 2018-06-12 | 东软集团股份有限公司 | 基于微服务架构的数据一致性方法以及装置 |
CN108647105A (zh) * | 2018-05-22 | 2018-10-12 | 阿里巴巴集团控股有限公司 | 系统切换过程中的幂等控制方法、装置及系统 |
CN109241186A (zh) * | 2018-08-29 | 2019-01-18 | 深圳市小牛在线互联网信息咨询有限公司 | 分布式事务的管理方法、系统、计算机设备及存储介质 |
CN109710625A (zh) * | 2018-12-20 | 2019-05-03 | 中科曙光国际信息产业有限公司 | 基于可靠消息的分布式一致性的实现方法 |
CN111510349A (zh) * | 2020-04-09 | 2020-08-07 | 上海东普信息科技有限公司 | 业务异常检测和告警方法、装置、设备及存储介质 |
CN111899105A (zh) * | 2020-08-04 | 2020-11-06 | 深圳乐信软件技术有限公司 | 系统异常处理方法、装置、计算机设备及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111030784A (zh) | 一种信息同步方法和装置 | |
CN109714409B (zh) | 一种消息的管理方法和系统 | |
CN111338834B (zh) | 数据存储方法和装置 | |
CN114827280A (zh) | 请求处理方法、装置、设备、介质 | |
CN107818027B (zh) | 名字节点主备切换的方法、装置和分布式系统 | |
CN114637611A (zh) | 基于消息队列的信息处理方法、装置及计算机设备 | |
CN112953769B (zh) | 数据传输方法、装置、计算机系统及可读存储介质 | |
CN112825525B (zh) | 用于处理事务的方法和装置 | |
CN111679892A (zh) | 分布式事务的处理方法、装置、设备及介质 | |
CN113783666B (zh) | 一种处理业务的方法和装置 | |
CN113783666A (zh) | 一种处理业务的方法和装置 | |
CN115374098A (zh) | 高并发支付订单防重方法、装置、系统、设备、介质和程序产品 | |
CN113157461B (zh) | 一种在执行任务单过程中传送消息的方法和装置 | |
CN113778631A (zh) | 分布式事务补偿方法、装置、电子设备及可读存储介质 | |
CN113590715A (zh) | 基于区块链的信息推送方法、装置、设备、介质和程序产品 | |
CN113781154A (zh) | 一种信息回滚方法、系统、电子设备及存储介质 | |
CN112181686A (zh) | 一种数据处理方法、装置、系统、电子设备及存储介质 | |
CN111210349A (zh) | 虚拟资产的转托管方法、装置、电子设备和存储介质 | |
CN110825610A (zh) | 一种用于提供测试数据的方法和装置 | |
US20240152504A1 (en) | Data interaction method, apparatus, and electronic device | |
CN114979187B (zh) | 一种数据处理方法及装置 | |
CN112950380B (zh) | 一种基于区块链的交易一致性的处理方法和装置 | |
CN114281604B (zh) | 数据恢复方法、装置、电子设备及存储介质 | |
CN113766437B (zh) | 一种短信发送方法和装置 | |
CN110011767B (zh) | 用于tcp连接备份的方法和装置 |
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 |