当前位置:首页 > 服务端 > SpringCloud Feign 配置(基于Consul)

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, 所以会尝试更换两次实例进行重试.

 

作者:小手星的矮子
来源链接:https://www.cnblogs.com/xiaoshouxing/p/9573887.html


版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/server/68568.html

分享给朋友: