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种路由过滤,每种过滤器都有独特的作用

网关登录校验

相关推荐
Xudde.12 小时前
班级作业笔记报告0x04
笔记·学习·安全·web安全·php
晓晓hh12 小时前
JavaSE学习——迭代器
java·开发语言·学习
421!13 小时前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
AI成长日志14 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
zzh08114 小时前
MySQL高可用集群笔记
数据库·笔记·mysql
小手指动起来14 小时前
保姆级提示词工程学习总结(含实操示例+工具推荐)
人工智能·学习·自然语言处理
绛橘色的日落(。・∀・)ノ15 小时前
Matplotlib实践学习笔记
笔记·学习
chase。15 小时前
【学习笔记】AGILE:把人形机器人强化学习从“玄学”变成“工程学”
笔记·学习·敏捷流程
久菜盒子工作室15 小时前
高等教育学|第一章高等教育概述
经验分享·笔记·课程设计
bu_shuo15 小时前
git练习学习网站【中文网站】
git·学习