SpringCloud Feign 配置(基于Consul)

Posted 小手星的矮子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud Feign 配置(基于Consul)相关的知识,希望对你有一定的参考价值。

一.基础配置

  1.引入依赖

     <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
       
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-discovery</artifactId>
        </dependency>

 

   2.创建主类,通过 @EnableFeginClients 注解开启 Feign 功能

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

    3.定义AService接口,通过 @FeignClient 注解指定服务名来绑定服务, 然后使用SpringMVC 的注解来绑定具体该服务提供的 REST 接口

@FeignClient("aservice")  //这里的服务名不区分大小写
public interface AService {
    @PostMapping("/hello")
    String hello();
}

    需要调用 AService 时,在类中使用 @Autowired 注解直接注入 AService 实例, 并调用 /hello 接口

@RestController
public class ConsumerController {

    @Autowired
    private AService aService;

    @RequestMapping("/test")
    public String test(){
        return aService.hello();
    }
}

 

二.参数绑定

@FeignClient("aservice") 
public interface AService {  
  @RequestMapping("/hello1")
   String hello1(@RequestParam("hello1") String hello1); 
  @RequestMapping("/hello2") 
  String hello2(@RequestHeader("hello2") String hello2)
  @RequestMapping("/hello3") 
  String hello2(@RequestBody User user)
}

 

   

@RestController
public class BController{  
  @RequestMapping(value = "/hello1", method = RequestMethod.GET)
   String hello1(@RequestParam String hello1){
    return "hello";
  }
  @RequestMapping(value =
"/hello2", method = RequestMethod.GET)   
  String hello2(@RequestHeader String hello2){
    return "hello";
  }
  
  @RequestMapping(value =
"/hello3", method = RequestMethod.POST)   
  String hello3(@RequestBody User user){
    return "hello";
  }
}

 

三.Ribbon 配置

  由于 Feign 的客户端负载均衡是通过 Ribbon 实现的, 所以可以通过配置 Ribbon 客户端的方式来自定义各个服务客户端调用的参数.

  1.全局配置

    全局配置直接使用 ribbon.<key>=<value>的方式来设置 ribbon 的各项默认参数. 比如, 修改默认的客户端调用超时时间:  

ribbon.ReadTimeout=5000
ribbon.ConnectTimeout=500

   2.指定服务配置

     大多数情况下, 服务调用的超时时间会根据实际服务的特性做一些调整, 所以需要指定服务配置

     指定服务配置根据 <client>.ribbon.key=value 的格式进行配置

aservice.ribbon.ReadTimeout=2000
aservice.ribbon.ConnectTimeout=500

    3.重试机制

ribbon.MaxAutoRetries=1
ribbon.MaxAutoRetriesNextServer=2

 

     MaxAutoRetries 设置为1, 所以重试策略先尝试访问首选实例一次,失败后才会更换实例访问,而更换实例访问的次数通过 MaxAutoRetriesNextServer 参数设置为2, 所以会尝试更换两次实例进行重试.

 

















以上是关于SpringCloud Feign 配置(基于Consul)的主要内容,如果未能解决你的问题,请参考以下文章

springCloud Spring Boot mybatis分布式微服务云架构-docker-feign-hystrix-ribbon

SpringCloud 声明式服务调用:Feign

springcloud之服务消费者(feign)

基于springcloud的灰度实现方案-feign调用

Feign自定义配置和编写Feign的Spring boot 插件

SpringCloud 进阶之Ribbon和Feign