OpenFeign和Consul爱恨交织的两天
1. 背景
在公司对项目进行拆分,用consul做注册中心。既然弄注册中心了, 那就得远程调用,那就得整上OpenFeign进行远程调用,你说是不? 不能说就搞个RestTemplate+服务名调用吧?想法有了,说动就动,就对项目就行拆分,在拆分的过程中,就把我学到的拿出来和大家分享分享。(我也是第一次用consul,没啥经验)
2. 爱与恨
2.1 恨
2.1.1 远程调用失败
在信息远程接口调用时,一直抛出异常:Load balancer does not have available server for client:xxx, 调用一直无法成功,看了很多解决办法,都没啥用。不过看这类型的日志我们知道,就是服务获取失败。 这真是一个头疼的问题(这个问题搞了一天),TMD,疼都炸了。说一下解决方案。
# 在application.yml中加上以下配置
spring:
cloud:
loadbalancer:
ribbon:
enabled: false
这个问题的根本原因就是consul整个openFeign用ribbon调用获取不到服务问题。把服务关闭就好了。
2.1.2 一个服务配置多个FeignClient
在拆分过程中,一个服务有很多service接口拿出来调用。例如:A服务中有 service1,service2,B在用Feign调用A接口时,就想对每个Service都有一个代理。默认情况下,不允许有多个代理。 看了很多,发现了一种最简单的写法,如下:
/**
* <br>通过contextId就可以区分</br>
*
* @author fattyca1
*/
@FeignClient(name = "PRODUCER", contextId = "bye")
public interface ByeService {
@RequestMapping("/bye")
String sayBye(@RequestParam("bye") String bye);
}
/**
* <br>ceshi</br>
*
* @author fattyca1
*/
@FeignClient(name = "PRODUCER", contextId = "hello")
public interface HelloService {
@RequestMapping("/hello")
String test(@RequestParam("hello") String hello);
}
2.1.3 consul注册服务覆盖
在用consul进行服务注册, 服务会被覆盖, 这个时候就要设置不同的InstantId和prefer-ip
就好了
2.2 爱
这还用想,当然是有学习到了啊,平时都是用的Eureka,突然换成consul,虽然原理是一样的,但是没想到还有不是很兼容的问题呀,学习到了一波。
当然,最终终于解决完问题,把服务拆好了,可以舒舒服服的修改代码了。
3. 总结
平时还得多用一些不一样的东西,然后接触不一样的问题,就可以不断扩展自己的知识圈,总结问题,学习方案。
你的每一个点赞,我都当做喜欢