这是我参与「掘金日新计划 · 6 月更文挑战」的第22天 ,点击查看活动详情
一、Feign
基本概念
-
Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。\
-
Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。\
-
Spring Cloud对Feign进行了增强,使Feign支持了Spring MVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。\
-
Spring Cloud Feign是基于Netflix feign实现,整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能外,还提供了一种声明式的Web服务客户端定义的方式。\
-
Spring Cloud Feign帮助我们定义和实现依赖服务接口的定义。在Spring Cloud feign的实现下,只需要创建一个接口并用注解方式配置它,即可完成服务提供方的接口绑定,简化了在使用Spring Cloud Ribbon时自行封装服务调用客户端的开发量。
二、实现服务调用
1、在调用端添加pom依赖
在statistics微服务中添加
可以删除之前添加的ribbon依赖,因为openfeign中封装了ribbon负载均衡
<!--服务调用-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2、启动类添加注解
@EnableFeignClients
3、创建远程调用包和接口
创建client包和UcenterClient接口
@FeignClient注解用于指定从哪个服务中调用功能 ,名称与被调用的服务名保持一致。
@GetMapping注解用于对被调用的微服务进行地址映射。
@PathVariable注解一定要指定参数名称,否则出错
@Component注解防止,在其他位置注入UcenterClient时idea报错
package com.guli.statistics.client;
@Component
@FeignClient("guli-ucenter")
public interface UcenterClient {
/**
* 注意:一定要写成 @PathVariable("day"),圆括号中的"day"不能少
* @param day
* @return
*/
@GetMapping(value = "/admin/ucenter/member/count-register/{day}")
public R registerCount(@PathVariable("day") String day);
}
4、调用微服务
修改DailyService中的createStatisticsByDay方法,调用client中的接口
实现
@Autowired
private UcenterClient ucenterClient;
@Transactional(rollbackFor = Exception.class)
@Override
public void createStatisticsByDay(String day) {
//删除已存在的统计对象
...
//获取统计信息
Integer registerNum = (Integer) ucenterClient.registerCount(day).getData().get("countRegister");
...
//创建统计对象
...
}
5、Swagger测试
启动eureka、ucenter、statistics三个微服务
在swagger中测试
\