berg369
berg369
采纳率63.2%
2020-04-26 09:48

微服务间调用能否自动判断本地调用还是远程调用从而采取不同方式?

20
已采纳

想实现的功能:

微服务间调用主要有springcloud和Dubbo两种,有时,小型项目或者服务器条件限制,多个服务组件可能打包为一个单体项目,或者打包为少数微服务,也可能所有服务组件单独打包为很多服务,例如开发了30个微服务工程,打包时可根据部署条件,打包到1个单体项目应用、3个应用(每个包含若干微服务)、30个应用(每个应用只包含一个微服务)这三种形式。那么服务间调用时,springcloud或dubbo能否动态的判断,如果是本地就直接依赖了避免网络请求及两次序列化转换性能更好,如果是远程再走远程调用机制,程序代码不动,能实现吗?

1、有意义吗?

这种做法追求本地调用和远程调用统一代码,意味着只能统一用java语言,而不支持其它(RestApi方式可支持所有语言,但写法明显不是java调用方式),但影响不大,这些微服务工程基于高内聚低耦合原则,之间调用并不多,但既然是写死在程序中,毕竟也是耦合的,可以建立自己的规则,不支持其它语言或第三方也没有关系。网上找不到这种作法的资料,这种做法有意义吗?

2、如何实现?

我的理解,springcloud基本是http请求,写法上与本地调用不同,实现上述要求有些困难,Dubbo写法上与本地请求一样,是否可以实现?怎么实现呢?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答

  • caozhy 从今以后生命中的每一秒都属于我爱的人 1年前

    可以把调用的部分抽象出来,也就是远程调用的stub代码和本地调用的proxy代码,使用相同的接口。
    这样可以保证上层调用的透明,不需要修改调用的代码,而把性能的优化放在底层。类似三层架构里面把 IDAO 接口和具体的数据库访问代码分离。

    在服务本身的设计上,应该统一,也就是说不要为不同调用路径编写不同代码,这样方便维护,也减少了单元测试的工作量。同时避免服务之间的耦合。

    点赞 评论 复制链接分享
  • weixin_37704897 weixin_37704897 1年前

    不是特别明白楼主的意思 。。。以springcloud为例,服务间的调用依赖于eureka(注册中心),各服务将自己注册到eureka(包含自己应用名、所在地址),
    不管是远程还是本地,无需自己判断,服务间的调用可用通过fegin来调用,只需要知道被调用的服务的名字就行,
    就像你去小超市直接给老板(eureka)说给我来瓶水,你不知道需要水在哪,但是老板知道它放在了哪

    点赞 评论 复制链接分享

相关推荐