SpringCloud学习笔记

Day04

OpenFeign

快速入门

OpenFeign是一个声明式的http客户端,是Springcloud在Eureka公式开源的Feign基础上改造而来的。其作用就是基于SpringMVC的常见注解,帮我们优雅实现http请求的发送

OpenFeign已经被SpringCloud自动装配,实现起来非常简单:

1、引入依赖,包括OpenFeign和负载均衡组件SpringCloudLoadBalancer

<!--openFeign-->

<dependency>

<groupId>org.springframework.cloud</groupId>

<artifactId>spring-cloud-starter-openfeign</artifactId>

</dependency>

<!--负载均衡器-->

<dependency>

<groupId>org.springframework.cloud</groupId>

<artifactId>spring-cloud-starter-loadbalancer</artifactId>

</dependency>

2、通过@EnableFeginClients注解,启用OpenFeign功能

@EnableFeignClients

@MapperScan("com.hmall.cart.mapper")

@SpringBootApplication

public class CartApplication {

public static void main(String[] args) {

SpringApplication.run (CartApplication.class, args);

}

@Bean

public RestTemplate restTemplate(){

return new RestTemplate();

}

}

3、编写FeignClient

@FeignClient(value = "item-service")

public interface ItemClient {

@GetMapping("/items")

List<ItemDTO> queryItemByIds(@RequestParam("ids") Collection<Long> ids);

}

4、使用FeignCLient

List<ItemDTO> items = itemClient.queryItemByIds(itemIds);

连接池

OpenFeign对Http请求做了优雅的伪装,不过其底层发起的Http请求,依赖于其他框架。这些框架可以自己选择,包括以下三种:

1、HttpURLConnection:默认实现,不支持连接池,不断的链接与断开开销大

2、Apache HttpClient:支持连接池

3、OKHttp:支持连接池

具体步骤:

1、引入依赖

<!--OK http 的依赖 -->

<dependency>

<groupId>io.github.openfeign</groupId>

<artifactId>feign-okhttp</artifactId>

</dependency>

2、开启连接池功能

在application.yml中添加配置:

feign:

okhttp:

enabled: true

最佳实践:

当定义的FeginClient不在SpringBootApplication的扫描包范围时,这些FeginClient无法使用。有两种解决方式:

1、指定FeginClient所在包

@EnableFeignClients(basePackages = "com.hmall.api.client")

2、指定FeignClient字节码

@EnableFeignClients(client={UserClient.class})

日志

OpenFeign只会在FeignClient所在包的日志级别为DEBUG时,才会输出日志。而且其日志级别有4级:

1、NONE:不记录任何日志信息,这是默认值

2、BASIC:仅记录请求的方法,URL以及响应状态码和执行时间

3、HEADERS:在BASIC的基础上,额外记录了请求和响应的头信息

4、FULL:记录所有请求和响应的明细,包括头信息、请求体、元数据

由于Feign默认的日志级别是NONE,所以默认我们看不到请求日志

自定义日志级别需要声明一个类型为Logger.Leve的Bean,在其中定义日志级别:

public class DefaultFeignConfig {

@Bean

public Logger.Level feignLoggerLevel(){

return Logger.Level.FULL ;

}

}

但此时这个Bean并未生效,要想配置某个FeignClient的日志,可以在@FeignCLient注解中声明:

@FeignClients(value="item-service",configuration = DefaultFeignConfig.class)

如果想要全局配置,让所有的FeignClient都按照这个日志配置,则需要在#EnableFeignClients注解中声明:

@EnableFeignClients(basePackages = "com.hmall.api.client",defaultConfiguration = DefaultFeignConfig.class)

网关

网关:就是网络的关口,负责请求的路由、转发、身份校验

网关从注册中心拉取所有的注册服务,前端访问时网关进行校验、路由、转发

在SpringCluod中网关的实现包括两种:

Spring Cloud Gateway:Spring官方出品,基于WebFlux响应式编程,无需调优即可获得优异性能

Netfilx Zuul:Netfile出品,基于Servlet的阻塞式编程,与Spring Cloud Gateway性能类似

配置网关

server:

port: 8080

spring:

application:

name: gateway

cloud:

nacos:

server-addr: 192.168.150.101:8848

gateway:

routes:

  • id: item-service

uri: lb://item-service

predicates:

  • Path=/items/**,/search/**

  • id: user-service

uri: lb://user-service

predicates:

  • Path=/users/**,/addresses/**

  • id: cart-service

uri: lb://cart-service

predicates:

  • Path=/cart/**

  • id: pay-service

uri: lb://pay-service

predicates:

  • Path=/pay/**

路由属性

网关路由对应的Java类型是RouteDefinition,其中常见的属性有:

id:路由的唯一标识

url:路由目标地址

predicate:路由断言,判断请求是否符合当前路由

filters:路由过滤器,对请求或响应做特殊处理

12种基本的RoutePredicateFactory实现:

路由过滤器:网关中提供了33种路由过滤,每种过滤器都有独特的作用

网关登录校验

相关推荐
zzcufo17 小时前
OpenScreenInPopUp
笔记·学习
Shining059617 小时前
CUDA 编程系列(三)《内存模型与规约优化》
人工智能·学习·其他·学习方法·infinitensor
71-317 小时前
MySQL的安装和卸载组件
笔记·学习·mysql
小付同学呀19 小时前
C语言学习(八)——C判断(switch语句)
c语言·学习·算法
科技林总19 小时前
【系统分析师】11.6 软件需求确认和验证
学习
ZTLJQ20 小时前
深入理解Autoencoder:无监督学习的异常检测与数据压缩利器
学习
夏星印20 小时前
argparse解析器参数详解
经验分享·笔记·python·学习·argparse
Shining059620 小时前
AI编译器系列(二)《AI 编译器中的前端优化》
人工智能·学习·其他·学习方法·infinitensor
码喽7号21 小时前
springboot学习四:RESTful风格+swagger
spring boot·学习·restful