[发明专利]服务的异步调用方法和装置有效
申请号: | 201910049835.9 | 申请日: | 2019-01-18 |
公开(公告)号: | CN109873863B | 公开(公告)日: | 2021-10-15 |
发明(设计)人: | 孙磊;沈迦勒 | 申请(专利权)人: | 北京百度网讯科技有限公司 |
主分类号: | H04L29/08 | 分类号: | H04L29/08 |
代理公司: | 北京英赛嘉华知识产权代理有限责任公司 11204 | 代理人: | 王达佐;马晓亚 |
地址: | 100085 北京市*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 服务 异步 调用 方法 装置 | ||
1.一种服务的异步调用方法,包括:
从预设消息队列中获取待处理的消息,其中,所述消息与调用方需要以异步调用方式调用的被调用方提供的接口相关联;
响应于经所述待处理的消息对应的执行时间确定待处理的消息为需处理的消息,基于待处理的消息,以异步调用方式调用被调用方提供的接口,得到调用结果;
执行与调用结果相关联的操作,与调用结果相关联的操作包括将待处理的消息设置为需要延迟处理的消息;
将所述需要延迟处理的消息放入与所设置的延迟的时间对应的延迟消息队列中,不同的延迟时间对应不同的延迟消息队列。
2.根据权利要求1所述的方法,其中,在所述响应于确定待处理的消息为需处理的消息,基于待处理的消息,以异步调用方式调用被调用方提供的接口,得到调用结果之前,所述方法还包括:
确定所述待处理的消息是否满足预设条件,所述预设条件包括:所述待处理的消息不与预设时长的判断时间段内从消息队列中获取的任意一个消息为同一个消息,所述判断时间段的结束时刻在确定消息队列中的消息是否满足处理条件的时刻之前;
当所述待处理的消息满足预设条件时,将所述待处理的消息确定为需处理的消息。
3.根据权利要求2所述的方法,其中,所述方法还包括:
生成所述待处理的消息对应的键值对,所述键值对包括:表示消息的标识的键、表示消息的属性信息的键值;以及
所述确定所述待处理的消息是否满足预设条件,包括:
查询预设键值对列表中是否存在所述待处理的消息对应的键;若不存在,则确定所述待处理消息满足预设条件;将所述待处理的消息对应的键值对添加至所述预设键值对列表;其中,所述预设键值对列表中存储所述预设时长的判断时间段内从消息队列中获取的多个消息各自对应的键值对。
4.根据权利要求2所述的方法,其中,在所述响应于确定待处理的消息为需处理的消息,基于待处理的消息,以异步调用方式调用被调用方提供的接口,得到调用结果之前,所述方法还包括:
当确定所述待处理的消息为需处理的消息时,将所述待处理的消息以及所述待处理的消息对应的执行时间信息添加入预设有序集合中;以及
所述响应于确定待处理的消息为需处理的消息,基于待处理的消息,以异步调用方式调用被调用方提供的接口,得到调用结果,包括:
在所述执行时间信息所指示的时刻,以异步调用方式调用与所述待处理的消息所关联的所述被调用方提供的接口,得到调用结果。
5.根据权利要求4所述的方法,其中,在所述执行与调用结果相关联的操作之前,所述方法还包括:
确定所述调用结果是否为预设调用返回结果;以及
所述执行与调用结果相关联的操作,包括:
若确定所述调用结果为预设调用返回结果,则执行从所述预设有序集合中删除所述待处理的消息及所述待处理的消息对应的执行时间信息的操作。
6.根据权利要求4所述的方法,其中,所述方法还包括:
每隔预设时间间隔,对所述预设有序集合进行检查,以检查预设有序集合是否存在已过执行时间的需处理的消息;
若存在,则以同步调用方式执行调用该需处理的消息对应的被调用方提供的接口的操作。
7.根据权利要求1所述的方法,其中,预设消息队列为分布式发布订阅消息系统中的预设消息队列。
8.一种服务的异步调用装置,包括:
获取单元,被配置成从预设消息队列中获取待处理的消息,其中,所述消息与调用方需要以异步调用方式调用的被调用方提供的接口相关联;
调用单元,被配置成响应于经所述待处理的消息对应的执行时间确定待处理的消息为需处理的消息,基于待处理的消息,以异步调用方式调用被调用方提供的接口,得到调用结果;
执行单元,被配置成执行与调用结果相关联的操作,与调用结果相关联的操作包括将待处理的消息设置为需要延迟处理的消息;将所述需要延迟处理的消息放入与所设置的延迟的时间对应的延迟消息队列中,不同的延迟时间对应不同的延迟消息队列。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京百度网讯科技有限公司,未经北京百度网讯科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910049835.9/1.html,转载请声明来源钻瓜专利网。