Spring cloud 中如何根据访问者的ip 将请求指向到指定的微服务中?

开发过程中,因为各微服务之间调用的关系,因此需要本地启用好几个微服务, 导致电脑内存使用率都在80%以上,有没有办法将几个微服务进行共用(例如: 服务注册发现Eureka,网关apigateway, 基础模块 base 等等),将共用的服务部署到192.168.1.11 服务器, 其他人(192.168.1.22, 192.168.1.33)在本地开发时,只需要启动一个OA模块, 加入到共用的服务器, 然后两人访问 192.168.1.11 上的eureka服务器, 网关根据来访者的ip, 到eureka中进行查找,如果有来访者ip对应的微服务,则将请求指向到该服务,否则指向到共用的服务?

11 服务器部署 Eureka 和 apigateway
22 和 33 开发人员本地开发OA模块, 都将他注册到11服务器
当22和33开发人员访问 11的网关的时候, 能够将他们访问OA模块的请求都转发到他们自己电脑上的服务上面去. 实现基础服务共用, 开发人员不需要本地启动eureka和apigateway,降低对开发人员电脑的内存使用率和负担

查阅了一番资料, 我这个应该算是负载均衡方面的问题, 通过Ribbon来实现请求分发,接下来看看怎么通过ip分发到指定的微服务.


慕神8447489
浏览 6451回答 2
2回答

qq_Thanandbest_0

我也遇到了这个问题,就是有两个相同的服务A分别部署在不同的服务器x和y上。当服务消费者访问服务A时,网关根据消费者的ip或其他信息将对A服务的使用下发到X服务器或Y服务器上。可以通过修改zuul中的负载均衡策略,但是没有找到如何配置的方法。请问你找到了???

潇潇雨雨

只要将服务注册到同一个注册中心,服务之间可以使用feignclient调用,没明白你说的什么意思。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java