Feign远程调用的使用
假设已配好nacos服务:并且已配好userservice、orderservice,点击跳转
Feign是一个声明式的http客户端,官方地址:https://github.com/OpenFeign/feign,其作用就是在程序中帮助我们优雅的实现http请求的发送,解决RestTemplate的远程调用硬编码的问题。
pom.xml
导入Feign依赖
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId><version>2.2.7.RELEASE</version>
</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 {@Autowiredprivate UserClient userClient; // 自动注入UserClientpublic 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 {@Beanpublic 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
导入依赖
<!--httpClient的依赖 -->
<dependency><groupId>io.github.openfeign</groupId><artifactId>feign-httpclient</artifactId><version>10.10.1</version>
</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 # 每个路径的最大连接数