springcloud-Feign负载均衡(基于服务端)
1 Feigin介绍
1.1 Feigin是什么
Feign是声明式Web Service客户端,它让微服务之间的调用变得更简单,类似于controller调用service。SpringCloud集成了Ribbon和Eureka,可以使用Feigin提供负载均衡的http客户端
Feign,主要是社区版,大家都习惯面向接口编程。这个是很多开发人员的规范。调用微服务访问两种方法
- 微服务名字 【ribbon】
- 接口和注解 【feign】
1.2 Feigin能干什么
- Feign旨在使编写Java Http客户端变得更容易
- 前面在使用Ribbon + RestTemplate时,利用RestTemplate对Http请求的封装处理,形成了一套模板化的调用方法。但是在实际开发中,由于对服务依赖的调用可能不止一处,往往一个接口会被多处调用,所以通常都会针对每个微服务自行封装一个客户端类来包装这些依赖服务的调用。所以,Feign在此基础上做了进一步的封装,由他来帮助我们定义和实现依赖服务接口的定义,在Feign的实现下,我们只需要创建一个接口并使用注解的方式来配置它 (类似以前Dao接口上标注Mapper注解,现在是一个微服务接口上面标注一个Feign注解),即可完成对服务提供方的接口绑定,简化了使用Spring Cloud Ribbon 时,自动封装服务调用客户端的开发量。
- Feign默认集成了Ribbon,利用Ribbon维护了MicroServiceCloud-Dept的服务列表信息,并且通过轮询实现了客户端的负载均衡,而与Ribbon不同的是,通过Feign只需要定义服务绑定接口且以声明式的方法,优雅而简单的实现了服务调用。
2 Feigin具体实现
基于:springcloud-Ribbon负载均衡(基于客户端)
2.1 创建模块
在父工程下新建一个普通的maven项目 springcloud-consumer-dept-feign
springcloud-consumer-dept-feign模块中的所有内容与springcloud-consumer-dept-80模块完全一致,只需要复制过来即可,然后修改一下启动类
springcloud-consumer-dept-feign : src/main/java/com/lv/springcloud/FeignDeptConsumer_80.java
package com.lv.springcloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
//Ribbon 和 Eureka 整合以后,客户端可以直接调用,不用关心IP地址和端口号
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients(basePackages = {"com.lv.springcloud"})
public class FeignDeptConsumer_80 {
public static void main(String[] args) {
SpringApplication.run(FeignDeptConsumer_80.class,args);
}
}
2.2 导入依赖
需要给springcloud-consumer-dept-feign和springcloud-api这两个模块导入feign依赖
springcloud-api : pom.xml
springcloud-consumer-dept-feign : pom.xml
<!--feign-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
2.3 创建service接口
在springcloud-api模块下新建一个service包,并在该包下创建一个DeptClientService 接口
springcloud-api : src/main/java/com/lv/springcloud/service/DeptClientService.java
package com.lv.springcloud.service;
import com.lv.springcloud.pojo.Dept;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import java.util.List;
@Component
@FeignClient(value = "SPRINGCLOUD-PROVIDER-DEPT")
public interface DeptClientService {
@GetMapping("/dept/get/{id}")
public Dept queryById(@PathVariable("id") Long id);
@GetMapping("/dept/list")
public List<Dept> queryAll();
@PostMapping("/dept/add")
public Boolean addDept(Dept dept);
}
2.4 修改控制层
修改springcloud-consumer-dept-feign模块的DeptConsumerController.java,将原来的Ribbon方式改为feign的方式
springcloud-consumer-dept-feign : src/main/java/com/lv/springcloud/controller/DeptConsumerController.java
package com.lv.springcloud.controller;
import com.lv.springcloud.pojo.Dept;
import com.lv.springcloud.service.DeptClientService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
public class DeptConsumerController {
@Qualifier("com.lv.springcloud.service.DeptClientService")
@Autowired
private DeptClientService service = null;
@RequestMapping("/consumer/dept/add")
public boolean add(Dept dept){
return this.service.addDept(dept);
}
@RequestMapping("/consumer/dept/get/{id}")
public Dept get(@PathVariable("id") Long id){
return this.service.queryById(id);
}
@RequestMapping("/consumer/dept/list")
public List<Dept> list(){
return this.service.queryAll();
}
}
对比Feign和Ribbon这两种方式,Feign显现出面向接口编程特点,代码看起来更清爽,而且Feign调用方式更符合我们之前在做SSM或者SprngBoot项目时,Controller层调用Service层的编程习惯!
2.5 测试
依次启动7001,8001,8002,和新创建的springcloud-consumer-dept-feign
启动成功后访问http://localhost/consumer/dept/list
成功查询出数据库中内容
3 Feign和Ribbon如何选择
- 根据个人习惯而定,如果喜欢REST风格使用Ribbon;如果喜欢社区版的面向接口风格使用Feign.
- Feign 本质上也是实现了 Ribbon,只不过后者是在调用方式上,为了满足一些开发者习惯的接口调用习惯!