Spring Cloud Alibaba - Feign
Feign
Feign简介
使用Feign实现消费者客户端
使用Feign+Ribbon实现客户端负载均衡
底层的负载均衡策略还是使用Ribbon通过Feign进行调用
Feign的相关配置
ribbon.eager-load.enabled=true
开启饥饿加载,默认是懒加载此项为false关闭状态,在调用的时候才开始获取服务列表进行负载均衡策略,所以第一次调用会比较缓慢,后面再次调用的速度会有大幅度提升。若设置为true打开状态,则从项目启动的时候就开始获取服务列表并且进行负载均衡策略,所以第一次调用并不会出现迟缓现象。
ribbon.eager-load.clients=xxxxxxxxxx
为哪些客户端开启饥饿加载,多个客户端使用逗号隔开(非必须),xxxxxxxx为客户端的服务名称。不配置的话如果配置了开启饥饿加载,则所有的客户端都开启
feign.client.config.default.read-timeout=2
设置feign读取时间为2 单位为毫秒,设置过小会出现读取超时现象
feign.client.config.default.connect-timeout=2
配置feign连接时间为2单位为毫秒,超过实现就不再连接
feign.client.config.default.logger-level=full
设置feign的日志记录等级
tips:default代表使用于所有服务
feign.client.config.[name].read-timeout=5
feign.client.config.[name].connect-timeout=5
配置具体服务的连接和读取时限,name为对应的服务名称
feign.httpclient.enabled=true
默认值也为true,代表是否使用默认的底层为Apache Http的客户端使用Feign
feign.httpclient.max-connections=200
指定客户端最大连接数
feign.httpclient.max-connections-per-route=50
指定每个路由路径的最大连接数
tips:feign的老版本底层采用的JDK的httpURLconnection发起远程调用,效率不如restTemplate,新版本效率差不多
脱离Ribbon的Feign远程调用
无负载均衡功能,只能使用远程调用
需要在@FeignClient注解中配置url属性,需要将连接地址写死。并且在接口中的方法上@GetMapping后面也不需要加路径,这样方法会自动调用url中的路径。
Feign的声明代码统一封装
实际开发时,会将有关于Feign的声明代码统一放入一个项目模块xxxxx-common中管理。实现代码复用,减少冗余。common模块中也需要引入相应的jar包依赖。
最新文章
- 怎样在Dos里切换盘符
- 《Spark快速大数据分析》—— 第五章 数据读取和保存
- java面试题个人总结
- Linux_DHCP服务搭建
- 利用WinHEX,重构狂牛加密视频1.0.0.1【只适合RIFF(AVI)】
- 【poj2828】Buy Tickets 线段树 插队问题
- dojo 十一 jsonp
- 【C#学习笔记】打开新进程
- Swift笔记4
- ViewFilpper
- 排序算法 - 插入排序(Insertion sort)
- Linux学习笔记--一些错误的记录
- 从零开始编写动态库文件Makefile,C++版
- 为ASP.NetCore程序启用SSL
- gitbook 入门教程之 gitbook 简介
- 【shiro】(2)---基于RUL的权限管理
- Lodop输出页面input文本框的最新值
- 2.4 if-else
- 【小程序】页面无法更新tabbar角标属性时
- 多线程出现 java.lang.NumberFormatException: multiple points