[发明专利]基于远程过程调用的服务分发方法、装置、介质及设备在审
申请号: | 202211051994.0 | 申请日: | 2022-08-30 |
公开(公告)号: | CN115421936A | 公开(公告)日: | 2022-12-02 |
发明(设计)人: | 郑博文;王丽桥;戴騄;李钰;韩冰杰;崔俊芬 | 申请(专利权)人: | 北京神舟航天软件技术股份有限公司 |
主分类号: | G06F9/54 | 分类号: | G06F9/54;G06F9/448;G06F9/455 |
代理公司: | 北京万驰专利代理事务所(普通合伙) 16106 | 代理人: | 王军 |
地址: | 100094*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 远程 过程 调用 服务 分发 方法 装置 介质 设备 | ||
公开了一种基于远程过程调用的服务分发方法、装置、介质及设备,该方法包括:获取待调用的软件功能代码中的通用业务逻辑代码,其中,待调用的软件功能代码中,因业务对象不通过而不同的业务逻辑部分通过服务接口来代替;通过工厂类获取与待调用的软件功能代码的服务接口的本地代理;根据待调用的软件功能代码的服务接口的调用方法与待调用的软件功能代码中的业务实现是否在同一个服务中,执行本地调用或者远程过程调用,实现业务对象在服务中的服务分发。该装置、介质及设备能够用于实现该方法。其可以支持同一虚拟机内的服务分发也可以支持跨JVM的服务分发,并且不管服务分发是否跨JVM其服务分发过程对上层的服务调用方来说都是透明和无感的。
技术领域
本发明涉及计算机程序数据管理技术领域,特别是涉及一种基于远程过程调用的服务分发方法、装置、介质及设备。
背景技术
在应用服务器软件开发过程中,通常需要根据业务对象的不同来改变业务实现逻辑,即按业务对象对软件服务进行分发,以满足软件功能需求。在单体服务架构中服务分发是在单一运行环境中完成的,但是,在微服务体系架构中业务实现逻辑分散在不同的服务中,存在微服务间进行服务分发的技术问题。
发明内容
有鉴于此,本发明提供了一种基于远程过程调用的服务分发方法、装置、介质及设备,可以支持同一虚拟机内的服务分发也可以支持跨JVM的服务分发,并且不管服务分发是否跨JVM其服务分发过程对上层的服务调用方来说都是透明和无感的,从而更加适于实用。
为了达到上述第一个目的,本发明提供的基于远程过程调用的服务分发方法的技术方案如下:
本发明提供的基于远程过程调用的服务分发方法包括以下步骤:
获取待调用的软件功能代码中的通用业务逻辑代码,其中,所述待调用的软件功能代码中,因业务对象不通过而不同的业务逻辑部分通过服务接口来代替;
通过工厂类获取与所述待调用的软件功能代码的服务接口的本地代理;
根据所述待调用的软件功能代码的服务接口的调用方法与所述待调用的软件功能代码中的业务实现是否在同一个服务中,执行本地调用或者远程过程调用,实现业务对象在服务中的服务分发。
本发明提供的基于远程过程调用的服务分发方法还可采用以下技术措施进一步实现。
作为优选,根据所述待调用的软件功能代码的服务接口的调用方法与所述待调用的软件功能代码中的业务实现是否在同一个服务中,执行本地调用或者远程过程调用,实现业务对象在服务中的服务实现具体包括以下步骤:
判断所述接口调用方法与服务实现是否在同一服务器中,
当所述待调用的软件功能代码的服务接口的调用方法与所述待调用的软件功能代码中的业务实现同在同一个服务器中时,直接在所述服务器中执行本地调用;
当所述待调用的软件功能代码的服务接口的调用方法与所述待调用的软件功能代码中的业务实现同在不同服务器中时,执行远程过程调用。
作为优选,所述当所述待调用的软件功能代码的服务接口的调用方法与所述待调用的软件功能代码中的业务实现同在不同服务器中时,执行远程过程调用具体包括以下步骤:
获取远程接口代理;
通过工厂类获取与所述待调用的软件功能代码的服务接口的本地代理;
执行本地调用,实现业务对象在服务中的服务实现。
作为优选,在所述步骤通过工厂类获取与所述待调用的软件功能代码的服务接口的本地代理与所述步骤执行本地调用,实现业务对象在服务中的服务实现之间,还包括以下步骤:
判断所述接口调用方法与服务实现是否在同一服务器中,
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京神舟航天软件技术股份有限公司,未经北京神舟航天软件技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202211051994.0/2.html,转载请声明来源钻瓜专利网。