您现在的位置是:亿华云 > 热点
Spring Cloud:使用 Feign 实现负载均衡详解
亿华云2025-10-04 00:24:43【热点】5人已围观
简介阅读文本大概需要 3 分钟。前面几篇文章,对 Ribbon 负载均衡做了详细的分析,这一节来介绍一下使用 Feign 负载均衡。在介绍之前,我们先来对 Feign 做一下简单的介绍,先来理解一下什么是
阅读文本大概需要 3 分钟。
前面几篇文章,负载对 Ribbon 负载均衡做了详细的均衡分析,这一节来介绍一下使用 Feign 负载均衡。详解在介绍之前,使实现我们先来对 Feign 做一下简单的负载介绍,先来理解一下什么是均衡 Feign。
1. Feign 是详解什么?
我们看一下官方的解释:Feign 是一个声明式 WebService 客户端。使用 Feign 能让编写的使实现 WebService 客户端更加简洁,它的负载使用方法式定义一个接口,然后在上面添加注解。均衡
Spring Cloud 对 Feign 进行了封装,详解使其支持了 Spring MVC 标准注解和 HttpMessageConverters。使实现Feign 可以与 Eureka 和 Ribbon 组合使用以支持负载均衡。负载
2. 为什么要使用 Feign?均衡
Feign 旨在使编写 Java Http 客户端变得更容易。前面在使用 Ribbon + RestTemplate 时,利用 RestTemplate 对 http 请求的封装处理,形成了一套模板化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一些客户端类来包装这些依赖服务的服务器托管调用。
所以,Feign 在此基础上做了进一步的封装,由它来帮助我们定义和实现依赖服务接口的定义。使用 Feign 只需要创建一个接口并使用一个注解来配置它即可。
这就类似于我们在 dao 层的接口上标注 @Mapper 注解一样。这样的话,即完成了对服务提供方的接口绑定,简化了使用 Spring Cloud Ribbon 时的开发量。我们用实例来说明。
3. Feign 的使用
3.1依赖导入
<!--eureka Client--><dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><!-- feign的支持 --><dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId></dependency>3.2启动类注解配置
@SpringBootApplication@EnableEurekaClient@EnableFeignClientspublic class OrderConsumerFeign{
public static void main(String[] args){
SpringApplication.run(OrderConsumerFeign.class, args);
}
}启动类需要添加注解 @EnableFeignClients,表示启用 Feign 客户端。
3.3Feign 客户端
我们先来回忆一下,提供订单的服务名称为:MICROSERVICE-ORDER,然后订单服务中提供的两个获取订单信息的接口url如下:
/
*** feign客户端
* @authorshengwu ni
*/ @FeignClient(value = "MICROSERVICE-ORDER")
public interface OrderClientService{
@GetMapping("/provider/order/get/{ id}")
TOrder getOrder(@PathVariable(value = "id") Long id);
@GetMapping("/provider/order/get/list")
List<TOrder> getAll();
}可以看到,Feign 客户端要添加 @FeignClient 注解,value 属性表示作用到哪个微服务上,这里表示负载均衡作用到请求订单服务上。要记住,Feign 也是客户端的负载均衡。高防服务器
方法内定义了两个接口,接口上即和普通的 SpringMVC 没什么区别,url 即订单提供服务的url。这就是 Feign 客户端,通过注解 + 接口的方式来和订单服务的接口绑定。
3.4Feign 客户端的使用
定义好了 Feign 客户端接口后,我们就可以在代码里通过 @Resource 正常引入进来,然后通过普通的方法调用即可实现对订单服务的调用,如下:
@RestController@RequestMapping("/consumer/order")
public class OrderConsumerController{
/
*** 上面定义的 Feign Client
*/ @Resource privateOrderClientService orderClientService;
@GetMapping("/get/{ id}")
public TOrder getOrder(@PathVariable Long id){
returnorderClientService.getOrder(id);
}
@GetMapping("/get/list")
public List<TOrder> getAll(){
returnorderClientService.getAll();
}
}启动 eureka 集群、三个订单提供服务和这个带有 Feign 的服务消费方(端口 9001)。通过在浏览器中访问:http://localhost:9001//consumer/order/get/1 可以看到,轮流访问三个订单服务。说明 Feign 默认是集成了 Ribbon 的轮询方案。
4. Feign 如何结合 Ribbon 切换均衡算法
以上就是 Feign 的使用,很简单,也符合我们平时的接口调用习惯。但是这是服务器租用默认的轮询负载均衡算法。在上一节我们知道,Ribbon 中支持很多自带的均衡算法,我们只要在代码中根据具体情况,选择合适的均衡算法即可。甚至我们可以选择自己自定义的均衡算法。
那么使用 Feign 的时候,如何去切换到 Ribbon 中其他均衡策略呢?甚至切换到自定义的策略呢?
也很简单,我们可以在 application.yml 配置文件中来指定,如下:
# feign和ribbon结合,指定策略。feign默认的是轮询的策略,这里的配置可以自定义
MICROSERVICE-ORDER:
ribbon:
NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRuleMICROSERVICE-ORDER 表示作用到哪个微服务,com.netflix.loadbalancer.RandomRule 即前面介绍 Ribbon 时里面的随机策略,当然,我们也可以指定为其他策略,包括我们自己定义的,只要把相应的包路径写到这即可,很方便。
重新启动一下服务消费方的程序,访问上面那个测试 url,可以看到三个订单服务是随机调用的,说明配置生效。
很赞哦!(183)
相关文章
- 只要我们做的是从目前的市场情况选择域名,从简单易记,从个性特征上,我们就可以找到一个好域名进行注册。域名注册进行域名记录和解析以及绑定网站后,客户可以通过URL登录您的网站。
- SpringCloud Alibaba微服务实战之业务日志组件
- 如何写出一套可维护的CSS库?
- 教你用Python玩转MySQL
- 以上的就是为大家介绍的关于域名的详解域名注册:域名注册0
- 10个解放双手的 IDEA 插件,这些代码真不用手写
- 2020年十大优秀设计系统
- 2021年15种主导软件开发行业发展的技术趋势
- a、变更前的公司证件扫描件(代码证或者营业执照)及联系人身份证复印件、变更后的公司证件扫描件(代码证或者营业执照)及新的联系人身份证复印件;身份证复印件需本人签名,公司证件复印件需加盖公章。
- 一日一技:如何捅穿Cloud Flare的5秒盾