SpringCloud Feign 配置(基于Consul)
2018-09-05 07:47:34来源:博客园 阅读 ()
一.基础配置
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, 所以会尝试更换两次实例进行重试.
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:并发编程十二问
下一篇:Java基础——String
- springboot2配置JavaMelody与springMVC配置JavaMelody 2020-06-11
- nacos~配置中心功能~springboot的支持 2020-06-10
- Maven安装与配置 2020-06-09
- Spring Boot 实现配置文件加解密原理 2020-06-08
- springboot 配置本地文件映射路径 2020-06-05
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash