文章目录
- 2.1 简单
- 2.2 Feign集成了Ribbon
- 第一步:创建客户端项目:springcloud-consumer-dept-feign
- 第二步: 导入依赖
- 第三步:配置application.yml
- 第四步:修改服务提供者:springcloud-api
- 第五步:在springcloud-consumer-dept-feign项目的controller也要做相应的修改
- 第六步:修改80主配置类
一、概念
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_spring cloud](//dev-img.mos.moduyun.com/20231020/00afaa6d-3226-4c48-bb38-f4790c38a9b9.png)
二、用处
2.1 简单
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_负载均衡_02](//dev-img.mos.moduyun.com/20231020/9e4c4bff-78a7-490e-a964-57bd8063eac4.png)
2.2 Feign集成了Ribbon
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_客户端_03](//dev-img.mos.moduyun.com/20231020/f556f8f3-f616-4241-b0bc-1e3eaa63b0e7.png)
三、实验
第一步:创建客户端项目:springcloud-consumer-dept-feign
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_云原生_04](//dev-img.mos.moduyun.com/20231020/93a33e57-53bb-4ded-b0b3-5da35a529eef.png)
创建一个springcloud-consumer-dept-feign空maven的空项目,这也是一个消费者,端口也是80,只是这个消费者使用Feign实现的负载均衡
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_负载均衡_05](//dev-img.mos.moduyun.com/20231020/d0862906-8c13-45ce-ad48-2396a1b8d97b.png)
第二步: 导入依赖
<dependencies>
<!--feign-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--Ribbon-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-ribbon</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--导入Ribbon的同时要导入erueka,因为它要发现服务从那里来-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<dependency>
<groupId>com.wu</groupId>
<artifactId>springcloud-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--热部署工具-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
</dependencies>
第三步:配置application.yml
和springcloud-consumer-dept-80项目的一摸一样
server:
port: 80
#Eureka配置
eureka:
client:
register-with-eureka: false #不向eureka中注册自己
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
第四步:修改服务提供者:springcloud-api
添加依赖
<!--feign-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
从前面了解到,Feign是通过注解接口,而Ribbon是通过微服务名字,那么下面给springcloud-api添加一个service包
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_spring_06](//dev-img.mos.moduyun.com/20231020/d0fd19be-cd10-45a4-a1a8-cbf84838a3f4.png)
书写接口
@Component
//Feign客户端的服务名
@FeignClient(value = "SPRINGCLOUD-PROVIDER-DEPT")
public interface DeptClientService {
@GetMapping("/dept/get/{id}")
Dept queryById(@PathVariable("id") Long id);
@PostMapping("/dept/add")
boolean addDept(Dept dept);
@RequestMapping("/dept/list")
List<Dept> queryAll();
}
第五步:在springcloud-consumer-dept-feign项目的controller也要做相应的修改
DeptConsumerController
@Controller
public class DeptConsumerController {
//这里直接把springcloud-api的DeptClientService接口注入进来
@Autowired
private DeptClientService deptClientService = null;
//然后通过接口来调用方法,调用方法后,它会调用上面类对应的方法,最后调用其服务名字的接口
@RequestMapping("/consumer/dept/get/{id}")
@ResponseBody
public Dept queryById(@PathVariable("id") Long id) {
return this.deptClientService.queryById(id);
}
@RequestMapping("/consumer/dept/add")
@ResponseBody
public boolean add(Dept dept) {
return this.deptClientService.addDept(dept);
}
@RequestMapping("/consumer/dept/list")
@ResponseBody
public List<Dept> queryAll() {
return this.deptClientService.queryAll();
}
}
第六步:修改80主配置类
![在这里插入图片描述 SpringCloud学习七:Feign负载均衡_负载均衡_07](//dev-img.mos.moduyun.com/20231020/991e7f28-6ad3-42b0-92f3-4e6ff5bf5d9a.png)
最后还要在启动类上添加FeignClient注解
FeignDeptConsumer_80
@SpringBootApplication
@EnableFeignClients(basePackages = {"com.kuang.springcloud"})
public class FeignDeptConsumer_80 {
public static void main(String[] args) {
SpringApplication.run(FeignDeptConsumer_80.class, args);
}
}
最后启动7001、… 、8001、… 、feign的80项目,测试