微服务——http客户端Feign

目录

Restemplate方式调用存在的问题

Feign的介绍

基于Feign远程调用

Feign自定义配置

修改日志方式一(基于配置文件)

修改日志方式二(基于java代码)

Feign的性能优化

连接池使用方法 

Feign_最佳实践分析 

 方式一:

方式二

 实现Feign最佳实践(方式二)

 两种解决方案


Restemplate方式调用存在的问题

微服务——http客户端Feign_第1张图片

Feign的介绍

就像早期的事务,需要手动的开启事务,提交事务,有了spring之后声明式事务只需要在配置文件里面定义好规则即可。

声明式http也是一样,提前定义好发送请求需要的信息,剩下的Feign完成。

微服务——http客户端Feign_第2张图片

基于Feign远程调用

定义和使用Feign客户端

微服务——http客户端Feign_第3张图片

 微服务——http客户端Feign_第4张图片

在这里刚好用到了所有在使用Restemplate发送请求时用到的数据。

微服务——http客户端Feign_第5张图片

业务代码如下

@Service
public class OrderService {

    @Autowired
    private OrderMapper orderMapper;

    @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;
    }
//    @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上的配置文件,不然项目会一直报错。


    com.alibaba.cloud
    spring-cloud-starter-alibaba-nacos-config

并且Feign里面自带一个ribbon,实现了负载均衡。

Feign自定义配置

微服务——http客户端Feign_第6张图片

修改日志方式一(基于配置文件)

微服务——http客户端Feign_第7张图片

没修改前:

 修改后:  输出日志瞬间多了很多

微服务——http客户端Feign_第8张图片

修改日志方式二(基于java代码)

微服务——http客户端Feign_第9张图片

Feign的性能优化

有了连接池可以减少性能损耗

微服务——http客户端Feign_第10张图片

连接池使用方法 

微服务——http客户端Feign_第11张图片

 微服务——http客户端Feign_第12张图片

Feign_最佳实践分析 

 方式一:

左下面这个消费者中的代码就是用注解声明远程调用的一些信息,用于发送请求到提供者中去。

右下面换这个提供者中的代码就是用于接收的类。

两个方法除了方法名不同,其余都相同。这两个是必须一样,不是巧合。

微服务——http客户端Feign_第13张图片微服务——http客户端Feign_第14张图片

 微服务——http客户端Feign_第15张图片

  spring官方有所一般情况下不推荐服务端和客户端共享接口,会造成紧耦合。

方式二

将对同一个服务同一些接口的FeignClinent抽取出来形成一个独立模块供所有的消费者使用。

微服务——http客户端Feign_第16张图片

 实现Feign最佳实践(方式二)

微服务——http客户端Feign_第17张图片

 按照上面方法测试会有一个报错

 'cn.itcast.feign.clients.UserClient' that could not be found.

不是编译报错,而是springIOC容器里面没有这个对象,无法实现自动注入。

这是因为下面这个接口原本有@FeignClient这个注解,spring扫描到了这个注解就会给该接口创建对象。现在因为不在启动类所在包里面了,扫描不到了。微服务——http客户端Feign_第18张图片

 两种解决方案

微服务——http客户端Feign_第19张图片

 推荐使用第二种,用到什么就指定什么。

你可能感兴趣的:(微服务,微服务,http,架构)