想实现的功能:
微服务间调用主要有springcloud和Dubbo两种,有时,小型项目或者服务器条件限制,多个服务组件可能打包为一个单体项目,或者打包为少数微服务,也可能所有服务组件单独打包为很多服务,例如开发了30个微服务工程,打包时可根据部署条件,打包到1个单体项目应用、3个应用(每个包含若干微服务)、30个应用(每个应用只包含一个微服务)这三种形式。那么服务间调用时,springcloud或dubbo能否动态的判断,如果是本地就直接依赖了避免网络请求及两次序列化转换性能更好,如果是远程再走远程调用机制,程序代码不动,能实现吗?
1、有意义吗?
这种做法追求本地调用和远程调用统一代码,意味着只能统一用java语言,而不支持其它(RestApi方式可支持所有语言,但写法明显不是java调用方式),但影响不大,这些微服务工程基于高内聚低耦合原则,之间调用并不多,但既然是写死在程序中,毕竟也是耦合的,可以建立自己的规则,不支持其它语言或第三方也没有关系。网上找不到这种作法的资料,这种做法有意义吗?
2、如何实现?
我的理解,springcloud基本是http请求,写法上与本地调用不同,实现上述要求有些困难,Dubbo写法上与本地请求一样,是否可以实现?怎么实现呢?