目录
Restemplate方式调用存在的问题
Feign的介绍
基于Feign远程调用
Feign自定义配置
修改日志方式一(基于配置文件)
修改日志方式二(基于java代码)
Feign的性能优化
连接池使用方法
Feign_最佳实践分析
方式一:
方式二
实现Feign最佳实践(方式二)
两种解决方案
Restemplate方式调用存在的问题
Feign的介绍
就像早期的事务,需要手动的开启事务,提交事务,有了spring之后声明式事务只需要在配置文件里面定义好规则即可。
声明式http也是一样,提前定义好发送请求需要的信息,剩下的Feign完成。
基于Feign远程调用
定义和使用Feign客户端
在这里刚好用到了所有在使用Restemplate发送请求时用到的数据。
业务代码如下
@Service
public class OrderService {@Autowiredprivate OrderMapper orderMapper;@Autowiredprivate UserClient userClient;public Order queryOrderById(Long orderId) {// 1.查询订单Order order = orderMapper.findById(orderId);//2.利用Feign远程调用User user = userClient.findById(order.getUserId());//3.封装user到orderorder.setUser(user);// 4.返回return order;}
// @Autowired
// private RestTemplate restTemplate;
//
// public Order queryOrderById(Long orderId) {
// // 1.查询订单
// Order order = orderMapper.findById(orderId);
// //2.利用RestTemplate发起http请求,查询用户
// String url="http://userserver/user/"+order.getUserId();
// User user = restTemplate.getForObject(url, User.class);
// //3.封装user到order
// order.setUser(user);
// // 4.返回
// return order;
// }
}
小问题_:如果项目里面引入了下面这注解就一定要去配置bootstrap.yml获取nacos上的配置文件,不然项目会一直报错。
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency>
并且Feign里面自带一个ribbon,实现了负载均衡。
Feign自定义配置
修改日志方式一(基于配置文件)
没修改前:
修改后: 输出日志瞬间多了很多
修改日志方式二(基于java代码)
Feign的性能优化
有了连接池可以减少性能损耗
连接池使用方法
Feign_最佳实践分析
方式一:
左下面这个消费者中的代码就是用注解声明远程调用的一些信息,用于发送请求到提供者中去。
右下面换这个提供者中的代码就是用于接收的类。
两个方法除了方法名不同,其余都相同。这两个是必须一样,不是巧合。
spring官方有所一般情况下不推荐服务端和客户端共享接口,会造成紧耦合。
方式二
将对同一个服务同一些接口的FeignClinent抽取出来形成一个独立模块供所有的消费者使用。
实现Feign最佳实践(方式二)
按照上面方法测试会有一个报错
'cn.itcast.feign.clients.UserClient' that could not be found.
不是编译报错,而是springIOC容器里面没有这个对象,无法实现自动注入。
这是因为下面这个接口原本有@FeignClient这个注解,spring扫描到了这个注解就会给该接口创建对象。现在因为不在启动类所在包里面了,扫描不到了。
两种解决方案
推荐使用第二种,用到什么就指定什么。