OpenFeign和Consul爱恨交织的两天

Posted 编号94530

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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. 总结

平时还得多用一些不一样的东西,然后接触不一样的问题,就可以不断扩展自己的知识圈,总结问题,学习方案。

以上是关于OpenFeign和Consul爱恨交织的两天的主要内容,如果未能解决你的问题,请参考以下文章

我与嵌入式软件开发爱恨交织的 7 年

爱恨交织的算法恨只因爱的太深--算法思想篇

分布式系列接口调用openfeign小试牛刀---openfeign接口是如何注入spring的

基于Consul的ConsulBlockingLoadBalancerClient(Spring Cloud 2020.0.1)

consul:kv

犯傻的两天。。。