这篇文章主要介绍了Gateway微服务网关,负载均衡,熔断和限流,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
工作原理
客户端向 Spring Cloud Gateway 发出请求。 如果网关处理程序映射确定请求与路由匹配,则将其发送到网关 Web 处理程序。 此处理程序通过特定于请求的过滤器链运行请求。 过滤器用虚线划分的原因是过滤器可以在发送代理请求之前和之后运行逻辑。 执行所有“预”过滤器逻辑。 然后发出代理请求。 发出代理请求后,将运行“发布”过滤器逻辑。
配置类分析
jar包中加载的配置类,会注入到IOC容器中。
1、GatewayClassPathWarningAutoConfiguration 检查是否有正确的配置webflux
检查是否有 org.springframework.web.servlet.DispatcherServlet
类,也就是是否引入了springweb的依赖。
2、GatewayAutoConfiguration 核心配置类
配置了很多bean,加载了gateway 需要注入的类。
配置了很多谓词想的的bean
3、GatewayLoadBalancerClientAutoConfiguration 网关需要使用的负载均衡
该过滤器实现了负载均衡的功能,通过责任链的设计模式。
4、GatewayRedisAutoConfiguration 网关整合Redis整合Lua实现限流
5、GatewayDiscoveryClientAutoConfiguration 把网关服务注册到注册中心中去,服务注册与发现功能
路由模式源码分析
网关的请求入口在 DispatcherHandler类里面的 handler 方法。
查找handler方法中,子类会查找路由策略,循环查找路由策略,第一个匹配的策略会返回了。
执行的handler
webHandler去执行
执行的是 filter 的 handler,gateway 默认有7个filter,分别实现了不同的功能:负载均衡、请求转发等功能。各个filter通过责任链模式循环执行。
解决前后端的跨域问题
微服务中跨域的问题,不属于前端解决 jsonp ,只能支持get请求。
核心点就是在我们后端。
解决跨域的问题
- HttpClient转发
- 使用过滤器允许接口可以跨域 响应头设置
- Jsonp 不支持我们的post 属于前端解决
- Nginx解决跨域的问题保持我们域名和端口一致性
- Nginx也是通过配置文件解决跨域的问题
- 基于微服务网关解决跨域问题,需要保持域名和端口一致性
- 使用网关代码允许所有的服务可以跨域的问题
- 使用SpringBoot注解形式@CrossOrigin
gateway解决跨域问题:增加过滤器,给请求头增加参数。
@Component
public class CrossOriginFilter implements GlobalFilter {
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
ServerHttpRequest request = exchange.getRequest();
ServerHttpResponse response = exchange.getResponse();
HttpHeaders headers = response.getHeaders();
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_ORIGIN, "*");
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_METHODS, "POST, GET, PUT, OPTIONS, DELETE, PATCH");
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_CREDENTIALS, "true");
headers.add(HttpHeaders.ACCESS_CONTROL_ALLOW_HEADERS, "*");
headers.add(HttpHeaders.ACCESS_CONTROL_EXPOSE_HEADERS, "*");
return chain.filter(exchange);
}
}
以上就是Gateway网关源码解析的详细内容,更多关于Gateway网关的资料请关注编程学习网其它相关文章!
本文标题为:Gateway网关源码解析
基础教程推荐
- JDK数组阻塞队列源码深入分析总结 2023-04-18
- java实现多人聊天系统 2023-05-19
- Java实现线程插队的示例代码 2022-09-03
- Java数据结构之对象比较详解 2023-03-07
- ConditionalOnProperty配置swagger不生效问题及解决 2023-01-02
- Java文件管理操作的知识点整理 2023-05-19
- springboot自定义starter方法及注解实例 2023-03-31
- Java并发编程进阶之线程控制篇 2023-03-07
- Java实现查找文件和替换文件内容 2023-04-06
- java基础知识之FileInputStream流的使用 2023-08-11