SpringCloud之Feign简介及使用
feign它让微服务之间的调用变得更简单了,类似controller调用service。Spring Cloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端。
使用过程
:
1 引入Feign
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-netflix-eureka-client</artifactId>
<version>2.1.2.RELEASE</version>
</dependency>
注:因为feign底层是使用了ribbon作为负载均衡的客户端,而ribbon的负载均衡也是依赖于eureka 获得各个服务的地址,所以要引入eureka-client。
2. SpringbootApplication启动类加上 @EnableFeignClients注解
@SpringBootApplication
@RefreshScope
@EnableDiscoveryClient
@EnableFeignClients
@EnableTransactionManagement
@MapperScan(value={"com.nari.base.mapper"})
@EnableEncryptableProperties //启动数据库加密功能
public class NariBaseApplication {
public static void main(String[] args) {
SpringApplication.run(NariBaseApplication.class, args);
}
- 接口调用
@FeignClient(value="gw-ua-web",path = "gw-ua-web/api/ua/auth")
public interface FeignService {
@RequestMapping(value="onlinenum",consumes = "application/json",method = RequestMethod.GET)
String getOnlinenum();
}
//或者这样调用(带传参的)
@FeignClient(value = "gw-ua-web")
public interface FeignService {
@GetMapping("/api/ua/auth/{productId}")
String getOnlinenum(@PathVariable("productId")Long productId);
}
- 上面是最简单的feign client的使用,声明完为feign client后,其他spring管理的类,如service就可以直接注入使用了,例如:
@Autowired
private FeignService feignService;
@GetMapping("test")
public Result test(){
String onlinenum = feignService.getOnlinenum();
log.info("在线用户数"+onlinenum);
}