使用feign进行服务调用
什么是Feign
Feign是spring cloud提供的一个声明式的伪http客户端,它使得调用远程服务就像调用本地服务一样简单,只需要创建一个接口并添加一个注解即可。
Nacos很好的兼容了Feign,Feign默认默认继承了Ribbon,所以在nacos下使用Feign默认就实现了负载均衡的效果。
Ribbon支持的负载均衡策略
负载均衡就是将请求分摊给多个实例进行进行处理。
根据负载均衡发生位置的不同,一般分为服务端负载均衡和客户端负载均衡。
服务端负载均衡指的是发生在服务提供者一方,比如常见的nginx负载均衡。
客户端负载均衡指的是发生在服务请求的一方,也就是在服务请求之前已经选好了由哪个实例进行处理。
我们在微服务中一般会选择客户端负载均衡,Ribbon就是在客户端进行了负载。
Ribbon内置了多种负载均衡策略,内部负载均衡的顶级接口为:com.netflix.loadbalancer.IRule,具体的负载策略如下图所示:
策略类 |
命名 |
描述 |
---|---|---|
RandomRule |
随机策略 |
随机选择server |
RoundRobinRule |
轮询策略 |
按照顺序选择server(ribbon默认策略) |
RetryRule |
重试策略 |
在一个配置时间段内,当选择server不成功,则一直尝试选择一个可用的server |
BestAvailableRule |
最低并发策略 |
逐个考察server,如果server断路器打开,则忽略,再选择其中并发链接最低的server |
AvailabilityFilteringRule |
可用过滤策略 |
过滤掉一直失败并被标记为circuit tripped的server,过滤掉那些高并发链接的server(active connections超过配置的阈值) |
ResponseTimeWeightedRule |
响应时间加权重策略 |
根据server的响应时间分配权重,响应时间越长,权重越低,被选择到的概率也就越低。响应时间越短,权重越高,被选中的概率越高,这个策略很贴切,综合了各种因素,比如:网络,磁盘,io等,都直接影响响应时间 |
ZoneAvoidanceRule |
区域权重策略 |
综合判断server所在区域的性能,和server的可用性,轮询选择server并且判断一个AWS Zone的运行性能是否可用,剔除不可用的Zone中的所有server |
如何使用Feign
我们使用第一章中的nacos-discovery-server作为服务提供者,提供了一个“/hello”的接口。新建一个alibaba-client-feign的服务作为消费者。
- pom文件中假如openfeign的依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
- 在启动类上加上支持feign的注解
@EnableFeignClients // 开启feign
- 创建一个feign客户端并使用feign调用微服务
// feign 客户端
@FeignClient(name="nacos-discovery-server")
interface Client{
@GetMapping("/hello")
String hello(@RequestParam String name);
}
// 消费服务
@RestController
class TestController{
@Autowired
Client client
@GetMapping("/test")
String test(){
// 调用生产者
return client.hello("hahaha");
}
}
注意:在实际开发中,feign客户端都是写在公共模块当中,哪个服务需要调用引入公共模块即可。
Feign的两种实现方式
- 第一种就是本文中介绍的,Feign和生产者的RequestMapping保持一致。
@FeignClient(name="nacos-discovery-server")
interface Client{
@GetMapping("/hello")
String hello(@RequestParam String name);
}
// 生产者
@RestController
class TestController{
@GetMapping("/hello")
String hello(@RequestParam String name){
return name;
}
}
- 第二种是在feignClient中提供所有请求的接口,然后controller实现这个feignClient,这样就不必要写重复代码了。
@FeignClient(name="nacos-discovery-server")
interface Client{
@GetMapping("/hello")
String hello(@RequestParam("name") String name);
}
@RestController
class producer implements Client{
@GetMapping("/hello")
@Override
public String hello(@RequestParam("name") String name) {
return name;
}
}
注意点
- 请求参数为对象是,使用@requestbody
- 请求参数用@requestParam接收时,必须加上value属性,如@requestParam("name")
- 请求参数用@pathVariable接收时,必须加上value属性,如@pathVariable("name")
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- linux|无需解压查看压缩文件内容
- R函数不会写,"抄"总会吧!
- @Resource和@Autowire的区别
- R函数,如何“抄”出水平
- 【STM32H7】第1章 当前主流的小型嵌入式GUI
- 链表反转的两种实现方法,后一种击败了100%的用户!
- envoy filter 开发实践系列 1:官网 echo 示例编译测试
- [Jmeter]---JsonPath表达式提取响应&断言
- envoy filter 开发实践系列 2:官网 http filter 示例编译测试
- 快速入门ElasticSearch
- 如何用 JS 一次获取 HTML 表单的所有字段 ?
- Docker与容器
- Go 每日一库之 air
- Go 每日一库之 goquery
- 个人电脑也做做宏基因组玩玩