五、SpringCloud-Gateway

Gateway的简单使用
摘要由CSDN通过智能技术生成

1.介绍

1.1.基本介绍

····Zuul是Netflix的开源项目,Spring Cloud将其收纳成为自己的一个子组件。zuul用的是多线程阻塞模型,它本质上就是一个同步 Servlet,这样的模型比较简单,他都问题是多线程之间上下文切换是有开销的,线程越多开销就越大。线程池数量固定意味着能力接受的请求数固定,当后台请求变慢,面对大量的请求,线程池中的线程容易被耗尽,后续的请求会被拒绝。
····Spring Cloud Gateway是Spring Cloud自己的产物,基于Spring 5 和Spring Boot 2.0 开发,Spring Cloud Gateway的出现是为了代替zuul,在Spring Cloud 高版本中没有对zuul 2.0进行集成,SpringCloud Gateway使用了高性能的Reactor模式通信框架Netty。

Gateway和zuul 2.0差别不是特别大,都是采用Netty高性能通信框架,性能都挺不错;
Gataway基于 Spring  5,Project Reactor ,  Spring Boot 2.0 ;
Gataway默认集成 Hystrix 断路器;
Gataway默认集成 Spring Cloud DiscoveryClient   (EurekaClient);
Predicates 和 Filters 作用于特定路由,易于编写的 Predicates 和 Filters
支持动态路由、限流、路径重写

1.2.核心概念

Filter(过滤器):
	Gateway的Filter和Zuul的过滤器类似,可以在请求发出前后进行一些业务上的处理 ;
	这里分为`两种类型的Filter,分别是Gateway Filter网关filter和Global Filter全局Filter;
Route(路由):
	一个Route模块由一个 ID,一个目标 URI,一组断言和一组过滤器定义;
	如果断言为真,则路由匹配,目标URI会被访问。
Predicate(断言):
	处理HTTP请求的匹配规则,在什么样的请情况下才能命中资源继续访问。

1.3.Gateway的工作方式

在这里插入图片描述····客户端向Spring Cloud Gateway发出请求。如果网关处理程序映射确定请求与路由匹配,则将其发送到网关Web处理程序。该处理程序通过特定于请求的过滤器链来运行请求。筛选器由虚线分隔的原因是,筛选器可以在发送代理请求之前和之后运行逻辑。所有“前置”过滤器逻辑均被执行。然后发出代理请求。发出代理请求后,将运行“后”过滤器逻辑。

2.Gateway入门

2.1.导入依赖

<!--服务注册与发现-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
导入了Eureka客户端jar包,因为需要注册到Eureka。

2.2.主配置类

@SpringBootApplication
@EnableDiscoveryClient
public class GatewayApp {
   
    public static void main(String[] args) {
   
        SpringApplication.run(GatewayApp.class,args);
    }
}

2.3.配置yaml

spring:
  application:
    name: gateway-server

  cloud:
    gateway:
      httpclient:
        connect-timeout
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值