Gateway网关学习

本文介绍了API网关的概念,特别是SpringCloudGateway的作用,包括请求分发、负载均衡和过滤拦截。详细讲述了如何集成和配置Gateway,如添加依赖、设置路由规则以及使用过滤器。同时,文章还讨论了过滤器的生命周期,并提到了局部路由过滤器和全局路由过滤器的区别。最后,文章展示了如何将Sentinel集成到Gateway中进行流控管理。
摘要由CSDN通过智能技术生成

什么是网关?

API网关 : 系统的统一入口

网关的作用

  1. 请求分发

  1. 负载均衡

  1. 过滤拦截

  1. 网络隔离

Gate集成

  1. 添加依赖

        <!--gateway网关-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
  1. 配置application.yml

spring:
  application:
    name: shop-gateway
    gateway:
      discovery:
        locator:
          enabled: true # 让gateway可以发现nacos中的微服务
  1. 自定义路由规则

id : 路由的标识

uri : 路由指向的目的地,转发到的微服务是哪个

predicate : 断言条件判断,只有true才会执行路由

filter : 过滤器用于修改请求和响应信息

spring:
  cloud:
    gateway:
      routes:
        - id: product_route
          uri: lb://product-service 
          predicates:
            - Path=/product-serv/**
          filters:
            - StripPrefix=1

Filter的生命周期

  • PRE : 在请求路由之前调用,可以利用这个过滤器实现身份验证

  • POST : 在路由到微服务以后执行,将响应从微服务发送给客户端

局部路由过滤器和全局路由过滤器

  • GatewayFilter : 对单个路由的过滤器,实现GatewayFilter接口

  • GlobalFilter : 对所有里有生效,不用配置,实现GlobalFilter接口

Gateway网关集成Sentinel

  1. 添加依赖

<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-spring-cloud-gateway-adapter</artifactId>
</dependency>
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-sentinel-gateway</artifactId>
</dependency>
  1. 配置application.yml

spring:
  cloud:
    sentinel:
      transport:
        port: 8719
        dashboard: localhost:8080
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
关于Spring Cloud Gateway的实战,有很多方面可以探索和实践。以下是一些常见的实战主题和示例: 1. 路由配置:使用Spring Cloud Gateway进行路由配置,将请求转发到不同的后端服务。可以通过YAML或Java代码方式进行配置,并可以使用各种条件和断言来实现动态路由。 2. 过滤器:利用Spring Cloud Gateway的过滤器功能,对请求进行预处理或后处理。常见的过滤器包括鉴权、请求转发修改、请求日志记录等。 3. 限流和熔断:使用Spring Cloud Gateway的限流和熔断功能,保护后端服务免受过载和故障的影响。可以使用内置的限流和熔断策略,或者集成第三方限流和熔断组件。 4. 请求重试:在网络不稳定的情况下,使用Spring Cloud Gateway的请求重试功能,自动重新发送请求,提高系统的可靠性和容错性。 5. 跨域支持:通过Spring Cloud Gateway配置跨域资源共享(CORS),允许跨域访问资源,提高前后端分离架构的灵活性。 6. 动态路由:结合服务注册中心(如Eureka或Consul)和配置中心(如Spring Cloud Config),实现动态路由的管理和配置。 7. 监控和日志:使用Spring Cloud Gateway的监控和日志功能,对请求进行统计和分析,了解系统的性能和健康状况。 以上只是一些常见的实战主题,实际上Spring Cloud Gateway还有更多功能和扩展性可供实践。你可以根据自己的需求和场景,选择适合的实战方向,深入学习和应用Spring Cloud Gateway
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值