博客
关于我
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/

    你可能感兴趣的文章
    Netty工作笔记0059---Netty私聊实现思路
    查看>>
    Netty工作笔记0060---Netty心跳机制实例
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0061---Netty心跳处理器编写
    查看>>
    Netty工作笔记0062---WebSocket长连接开发
    查看>>
    Netty工作笔记0063---WebSocket长连接开发2
    查看>>
    vue样式穿透 ::v-deep的具体使用
    查看>>
    Netty工作笔记0065---WebSocket长连接开发4
    查看>>
    Netty工作笔记0066---Netty核心模块内容梳理
    查看>>
    Vue基本使用---vue工作笔记0002
    查看>>
    Netty工作笔记0068---Protobuf机制简述
    查看>>
    Netty工作笔记0069---Protobuf使用案例
    查看>>
    Netty工作笔记0070---Protobuf使用案例Codec使用
    查看>>
    Netty工作笔记0071---Protobuf传输多种类型
    查看>>
    Netty工作笔记0072---Protobuf内容小结
    查看>>
    Netty工作笔记0073---Neety的出站和入站机制
    查看>>
    Netty工作笔记0074---handler链调用机制实例1
    查看>>
    Netty工作笔记0075---handler链调用机制实例1
    查看>>
    Netty工作笔记0076---handler链调用机制实例3
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>