博客
关于我
Spring cloud gateway实现Api网关(nacos+gateway)
阅读量:582 次
发布时间:2019-03-11

本文共 2158 字,大约阅读时间需要 7 分钟。

核心概念

在Spring Cloud Gateway中,我们可以通过配置路由规则来管理各服务之间的请求转发。以下是常见的路由配置方式和策略。

路由规则配置

bootstrap.yml中,通过设置路由规则,可以实现对请求的智能转发。以下是一些常用的路由规则配置方式:

  • 路径规则(Path Predicate)
  • cloud:  gateway:    routes:      - id: shop-goods        uri: http://localhost:9101/  # 目标URI        predators:          - Path=/goods/**  # 匹配路径为 `/goods/****` 的请求
    1. 查询参数规则(Query Predicate)
    2. cloud:  gateway:    routes:      - id: shop-goods        uri: http://localhost:9101/  # 目标URI        predicates:          - Query=token  # 匹配请求参数中包含 `token` 的请求          - Query=pattern  # 对查询参数进行正则匹配

      例如:- Query=token,\d+ 表示匹配请求参数中包含以数字开头的 token

      1. 请求方法规则(Method Predicate)
      2. cloud:  gateway:    routes:      - id: shop-goods        uri: http://localhost:9101/  # 目标URI        predators:          - Method=GET  # 匹配所有 GET 请求
        1. 时间规则(DateTime Predicate)
        2. cloud:  gateway:    routes:      - id: shop-goods        uri: http://localhost:9101/  # 目标URI        predators:          - After=2021-04-25T10:00:00+08:00[Asia/Shanghai]  #匹配2021年4月25日10点之后的请求

          可选其他时间规则:

          • Before:匹配请求时间之前的请求
          • Between:匹配在两个时间之间的请求
          1. 远程地址规则(RemoteAddr Predicate)
          2. cloud:  gateway:    routes:      - id: shop-goods        uri: http://localhost:9101/  # 目标URI        predicates:          - RemoteAddr=192.168.100.0/24  # 匹配访问地址在192.168.100.0/24 子网内的请求
            1. 请求头规则(Header Predicate)
            2. cloud:  gateway:    routes:      - id: shop-goods        uri: http://localhost:9101/  # 目标URI        predators:          - Header=token,\d+  # 匹配请求头中携带 `token` 并以数字开头的值

              动态路由(服务发现路由规则)

              在Spring Cloud Gateway中,我们可以通过服务发现机制,将路由规则动态注册到服务注册中心(如Nacos),从而实现路由规则的动态配置。

              动态路由实现步骤

              1. 使用Nacos作为服务注册中心

              配置bootstrap.yml,启用Nacos的服务发现功能,设置动态路由。

              cloud:  gateway:    discovery:      enabled: true      lower-case-service-id: true
              2. 配置Nacos服务器地址和命名空间
              nacos:  discovery:    server-addr: localhost:8848  # Nacos注册中心地址    namespace: 0e883794-4414-4d41-a177-6d335d304e42  # 开发环境命名空间ID  config:    server-addr: localhost:8848  # Nacos配置中心地址    namespace: 0e883794-4414-4d41-a177-6d335d304e42  # 开发环境命名空间ID
              3. 服务名称转发

              在动态路由中,通过Nacos发现服务,可以实现服务名称的自动转发,简化路由配置。

              cloud:  gateway:    discovery:      locator:        enabled: true  # 启用服务发现路由

              总结

              以上配置方法可以根据实际需求灵活调整。通过配置不同的路由规则,可以实现请求的智能转发和动态管理。具体应用时,可以根据实际场景选择合适的路由策略。

    转载地址:http://kvftz.baihongyu.com/

    你可能感兴趣的文章
    netty2---服务端和客户端
    查看>>
    【Flink】Flink 2023 Flink易用性和稳定性在Shopee的优化-视频笔记
    查看>>
    Netty5.x 和3.x、4.x的区别及注意事项(官方翻译)
    查看>>
    netty——bytebuf的创建、内存分配与池化、组成、扩容规则、写入读取、内存回收、零拷贝
    查看>>
    netty——Channl的常用方法、ChannelFuture、CloseFuture
    查看>>
    netty——EventLoop概念、处理普通任务定时任务、处理io事件、EventLoopGroup
    查看>>
    netty——Future和Promise的使用 线程间的通信
    查看>>
    netty——Handler和pipeline
    查看>>
    Vue输出HTML
    查看>>
    netty——黏包半包的解决方案、滑动窗口的概念
    查看>>
    Netty中Http客户端、服务端的编解码器
    查看>>
    Netty中使用WebSocket实现服务端与客户端的长连接通信发送消息
    查看>>
    Netty中实现多客户端连接与通信-以实现聊天室群聊功能为例(附代码下载)
    查看>>
    Netty中的组件是怎么交互的?
    查看>>
    Netty中集成Protobuf实现Java对象数据传递
    查看>>
    netty之 定长数据流处理数据粘包问题
    查看>>
    Netty事件注册机制深入解析
    查看>>
    netty代理
    查看>>
    Netty入门使用
    查看>>
    netty入门,入门代码执行流程,netty主要组件的理解
    查看>>