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

    你可能感兴趣的文章
    oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
    查看>>
    oracle零碎要点---oracle em的web访问地址忘了
    查看>>
    Oracle零碎要点---多表联合查询,收集数据库基本资料
    查看>>
    Oracle静默安装
    查看>>
    Oracle面试题:Oracle中truncate和delete的区别
    查看>>
    Oracle:ORA-00911: 无效字符
    查看>>
    TCP基本入门-简单认识一下什么是TCP
    查看>>
    Orcale表被锁
    查看>>
    org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
    查看>>
    org.apache.poi.hssf.util.Region
    查看>>
    org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
    查看>>
    org.hibernate.HibernateException: Unable to get the default Bean Validation factory
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size exceeded
    查看>>
    org.tinygroup.serviceprocessor-服务处理器
    查看>>
    org/eclipse/jetty/server/Connector : Unsupported major.minor version 52.0
    查看>>
    org/hibernate/validator/internal/engine
    查看>>
    SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
    查看>>
    ORM sqlachemy学习
    查看>>