先启动两个服务分别orderservice userservice
1.引入依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.在order-service的启动类添加注解开启Feign的功能:
@EnableFeignClients
@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
public class OrderApplication
public static void main(String[] args) {
SpringApplication.run(OrderAppLication.class, args);
}
3.定义和使用Feign客户端
使用Feign的步骤如下:
编写Feign客户端:
@FeignClient("userservice")
public interfacè UserClient {
@GetMapping("/user/{id}")
User findById(@PathVariable("id") Long id);
}
主要是基于SpringMVC的注解来声明远程调用的信息,比如:
·服务名称:userservice
·请求方式:GET
·请求路径:/user/{id}
·请求参数:Long id
·返回值类型:User
注意:要让两个服务处于一个集群内
否则会出现检测不到服务的情况
关于Feign的自定义配置方式
Feign的日志配置:
1.方式一是配置文件,feign.client.config.xxx.loggerLevel
①如果xxx是default则代表全局
②如果xxx是服务名称,例如userservice则代表某服务
2.方式二是java代码配置Logger.Level这个Bean
①如果在@EnableFeignClients注解声明则代表全局
②如果在@FeignClient注解中声明则代表某服务
public class FeignClientConfiguration {
@Bean
public Logger.Level FeignlogLervel(){
return Logger.Level.BASIC;
}
}
Feign的性能调优
Feign底层的客户端实现:
· URLConnection:默认实现,不支持连接池
· Apache HttpClient:支持连接池
· OKHttp:支持连接池
因此优化Feign的性能主要包括:
1.使用连接池代替默认的URLConnection
2.日志级别,最好用basic或none
方法一:
Feign的性能优化-连接池配置
Feign添加HttpClient的支持:
引入依赖:
<!-- httpClient的依赖-->
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-httpclient</artifactId>
</dependency>
配置连接池:
feign:
client:
config:
default:# default全局的配置
LoggerLevel:BASIC # 日志级别,BASIC就是基本的请求和响应信息
httpclient:
enabled:true # 开启feign对HttpClient的支持
max-connections:200 # 最大的连接数
max-connections-per-route:50 # 每个路径的最大连接数
Feign的优化:
1.日志级别尽量用basic
2.使用HttpClient或OKHttp代替URLConnection
①引入feign-httpClient依赖
②配置文件开启httpClient功能,设置连接池参数
Feign最佳实践
当定义的FeignClient不在SpringBootApplication的扫描包范围时,这些FeignClient无法使用。有两种方式解决:
方式一:指定FeignClient所在包
@EnableFeignClients(basePackages ="cn.itcast.feign.clients")
方式二:指定FeignClient字节码
@EnableFeignCLients(clients = {UserClient.class})