Feign远程调用的使用

假设已配好nacos服务:并且已配好userservice、orderservice,点击跳转

Feign是一个声明式的http客户端,官方地址:https://github.com/OpenFeign/feign,其作用就是在程序中帮助我们优雅的实现http请求的发送,解决RestTemplate的远程调用硬编码的问题。

pom.xml导入Feign依赖

<dependency>
    <groupId>org.springframework.cloudgroupId>
    <artifactId>spring-cloud-starter-openfeignartifactId>
    <version>2.2.7.RELEASEversion>
dependency>

 


 

在启动类OrderApplication.java中添加开启Feign注解

@EnableFeignClients  // 开启Feign
@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
public class OrderApplication {
	...
}

 


 

新建文件UserClient.java编写Feign客户端:

@FeignClient("userservice")  // userservice为nacos远程调用的服务端名称
public interface UserClient {
    @GetMapping("/user/{id}")		// 请求地址为:http://userservice/user/{id}
    User findById(@PathVariable("id") Long id);
}

 


 

TestService.java测试使用

public class OrderService {
    @Autowired
    private UserClient userClient;		// 自动注入UserClient

    public Order queryOrderById(Long orderId) {
        Order order = orderMapper.findById(orderId);
        
        User user = userClient.findById(order.getUserId());  // Feign远程调用 http://userservice/user/{id}
        
        order.setUser(user);
        return order;
    }
}

 


 

自定义的一些配置:如日志级别

方式一:application.yml配置文件

feign:
  client:
    config:
  	  userservice: # 针对某个服务
      	logger-level: FULL  # 日志级别
      #default: # default就是全局配置,如果是写服务名称,则是针对某个微服务的配置
        #logger-level: BASIC

方式二: 重写Logger.Level的Bean实列

DefaultFeignConfig.java

// @Configuration // 如果不想要配置以下两种,则直接加这个注解,让spring扫描到
public class DefaultFeignConfig {
    @Bean
    public Logger.Level feignLogLevel() {
        return Logger.Level.FULL;
    }
}

1. 如果要全局生效,将其放到Application.java启动类的@EnableFeignClients这个注解中:

@EnableFeignClients(defaultConfiguration = DefaultFeignConfig.class) 

2. 如果是局部生效,则把它放到对应的@FeignClient这个注解中:也就是上面的UserClient.java中加入以下注解

@FeignClient(value = "userservice", configuration = DefaultFeignConfig.class) 

 


 

Fegin 开启(Apache HttpClient)连接池

默认是URLConnection,不支持连接池。

pom.xml导入依赖


<dependency>
    <groupId>io.github.openfeigngroupId>
    <artifactId>feign-httpclientartifactId>
    <version>10.10.1version>
dependency>

配置文件application.yml配置httpclient连接池参数

feign:
  client:
    config:
      default: # default全局的配置
        loggerLevel: BASIC # 日志级别,BASIC就是基本的请求和响应信息
  httpclient: # httpclient连接池
    enabled: true 	# 开启feign对HttpClient的支持
    max-connections: 200 	# 最大的连接数
    max-connections-per-route: 50 	# 每个路径的最大连接数

你可能感兴趣的:(微服务,微服务,Feign,RPC,远程调用)