学习笔记——微服务治理(一)
中间件——Feign
目的:解决RestTemplate在代码中出现的url问题。代码中出现url,不方便代码的维护,涉及到接口地址一旦发送改变就要修改一些需要远程调用这些url的业务模块。因此采用Feign进行远程调用。
实现步骤:
- 在需要远程调用其他业务模块的模块中,将pom.xml中添加Feign依赖
<!-- feign 客户端依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
并添加HttpClient的支持
<!-- httpClient 的依赖-->
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-httpclient</artifactId>
</dependency>
2.在需要调用其他业务模块的模块中,将配置文件application.xml中配置httpClient
feign:
httpclient:
enabled: true # 支持httpClient的开关
max-connections: 200 #最大连接数
max-connections-per-route: 50 # 单个路径的最大连接数
3.创建feign-api模块,将远程调用的接口抽取出来,方便后期的维护
日志设置为:
public class DefaultFeignConfiguration {
@Bean
public Logger.Level logLevel(){
return Logger.Level.BASIC;
}
}
4.在需要调用其他业务模块的模块中,导入feign-api模块
<!-- 引用feign的统一API-->
<dependency>
<groupId>cn.itcast.demo</groupId>
<artifactId>feign-api</artifactId>
<version>1.0</version>
</dependency>
5.在需要调用其他业务模块的模块中,添加注解
@EnableFeignClients(defaultConfiguration = DefaultFeignConfiguration.class
,clients = {UserClient.class})
PS:
参数:clients = {UserClient.class} 是让spring扫描到Feign-api模块中管理userservice接口的接口UserClient。具体spring是如何将一个接口注入到IOC容器中,涉及到@EnableFeignClients注解。
在**@EnableFeignClients注解中**,介绍到:扫描那些声明自己是为客户端的接口(通过FeignClient @FeignClient)。
配置用于org.springframework.context.annotation.Configuration @Configuration类的组件扫描指令。
@FeignClient("userservice")
public interface UserClient {
@GetMapping("/user/{id}")
User findById(@PathVariable Long id);
}
在需要调用其他业务模块的模块中,会扫描到带有@FeignClient注解的接口。
6.在需要调用其他业务模块的模块中,通过@Autowired获取IOC容器中的UserClient,调用其方法
@Autowired
private UserClient userClient;
public Order queryOrderById(Long orderId) {
// 1.查询订单
Order order = orderMapper.findById(orderId);
// 2.Feign 发送远程调用
User user = userClient.findById(order.getUserId());
// 3.将user 存入order中
order.setUser(user);
// 4.返回
return order;
}
总结:
使用Feign时,涉及到:
- 接口的抽取
- 性能优化