您当前的位置:首页 > 电脑百科 > 网络技术 > 网络知识

SpringCloud Gateway动态路由之Nacos

时间:2020-10-19 13:32:48  来源:  作者:

前言

当我们的网关Gateway程序开发完成之后,需要部署到生产环境,这个时候你的程序不能是单点运行的,肯定是多节点启动(独立部署或者Docker等容器部署),防止单节点故障导致整个服务不能访问,网关是对客户端的入口与出口,在生产运行中极为重要,哪怕是简单的重启也会导致部分请求的丢失。

网关的路由配置这个时候就是一个大问题,是代码里面编写还是配置文件配置?他们都有一个致命的缺点,当有新的程序需要接入到网关进行路由或者有服务需要下线时候需要修改代码或者配置,然后重启整个网关程序,导致其他正常的服务路由受到了影响。

所以在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启网关,所以实现动态路由是非常有必要的;

本文主要介绍 Spring Cloud Gateway 实现的思路,并且把路由信息存放在外部源中,这粒以Nacos为数据源来讲解

实现要点

要实现动态路由只需关注下面4个点

  1. 网关启动时,动态路由的数据怎样加载进来
  2. 静态路由与动态路由以那个为准
  3. 监听动态路由的数据源变化
  4. 数据有变化时怎样通知gateway刷新路由

ps:静态路由指的是配置文件里写死的路由配置

具体实现

Spring Cloud Gateway 中加载路由信息分别由以下几个类负责

  1. PropertiesRouteDefinitionLocator:从配置文件中读取路由信息(如YML、Properties等)
  2. RouteDefinitionRepository:从存储器中读取路由信息(如内存、配置中心、redisMySQL等)
  3. DiscoveryClientRouteDefinitionLocator:从注册中心中读取路由信息(如Nacos、Eurka、Zookeeper等)

我们可以通过自定义 RouteDefinitionRepository 的实现类来实现动态路由的目的

实现动态路由的数据加载

我们可以查看源码RouteDefinitionRepository的存储的实现类,只有InMemoryRouteDefinitionRepository,此实现类是存放在内存中的。

我们可以重新定义一个nacos作为存储的实现,看下面的代码

SpringCloud Gateway动态路由之Nacos

 


SpringCloud Gateway动态路由之Nacos

 


SpringCloud Gateway动态路由之Nacos

 

上面代码核心的是 重写 getRouteDefinitions 方法实现路由信息的读取 ;这个方法中涉及到了ConfigService对象Api的方法

管理Api方法,这个老顾这里不详细说了;小伙伴们可以理解为就是操作nacos config的对象

配置Nacos监听器,监听路由配置信息的变化,也是利用api方法,也就是addListener方法;此方法一看就知道,就是用来监听config信息变化的。

此addListener方法中路由变化只需要往 ApplicationEventPublisher 推送一个 RefreshRoutesEvent 事件,即刻gateway会自动监听该事件并调用 getRouteDefinitions 方法更新路由信息 。

这样就达到了动态更新路由了。

配置类

为了更好的把此动态路由作为公共core,我们需要利用配置类,达到是否启用的方式;可以让开发者自行配置。

SpringCloud Gateway动态路由之Nacos

 

上面的配置类,有两个重要的@ConditionalOnProperty,这个就是用来控制是否启用动态路由,以及是否用nacos作为存储。

里面还有@Value注解定义我们存储路由信息的DataId和Group,application.yml如果不配置默认值为scg-routes和SCG_GATEWAY

添加Nacos路由配置

在同一个namespace中创建scg-routes和SCG_GATEWAY

SpringCloud Gateway动态路由之Nacos

 

格式选择json,json体里面的格式其实就是RouteDefinition类的属性

SpringCloud Gateway动态路由之Nacos

 

注意上面的配置的json是数组格式哦,也就是可以有很多路由哦

[{
    "id": "baidu",
    "order": 0,
    "predicates": [{
        "args": {
            "pattern": "/baidu/**"
        },
        "name": "Path"
    }],
    "uri": "https://www.baidu.com"
},{
    "id": "sina",
    "order": 2,
    "predicates": [{
        "args": {
            "pattern": "/sina/**"
        },
        "name": "Path"
    }],
    "uri": "http://www.sina.com.cn"
}]

测试

在网关项目中的application.yml中配置

rainbow: 
  gateway: 
    dynamicRoute: 
      enabled: true

启动网关,就可以了;为了方便看到网关当前的路由信息,我们需要引入

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

并且在application.yml中配置

management:
  endpoints:
    web:
      exposure:
        include: '*'
  endpoint:
    gateway:
      enabled: true
    health:
      show-details: always

这样我们就可以访问http://localhost:8081/actuator/gateway/routes,就可以看到路由信息

SpringCloud Gateway动态路由之Nacos

 

小伙伴们可以尝试修改一下nacos中的dataId为scg-routes,我们可以发现路由及时得到了更改。

老顾只修改了route_id的名称,路由就及时更新了

SpringCloud Gateway动态路由之Nacos

 

我们也看到了控制台日志也有相应的变化

SpringCloud Gateway动态路由之Nacos

 

总结

gateway的动态路由是非常实用的功能,在生产环境中是必备功能,小伙伴们一定要掌握哦,当然小伙伴们也可以用其他的数据源。谢谢!!!



Tags:动态路由   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
一、动态路由RIP产生背景1、动态路由协议包括距离向量路由协议和链路状态路由协议。RIP(Routing InformationProtocols,路由信息协议)是使用最广泛的距离向量路由协议。RIP 是...【详细内容】
2020-12-23  Tags: 动态路由  点击:(546)  评论:(0)  加入收藏
1、 为什么要用到GRE over IPSec、IPSec over GRE或SVTI为什么要使用GRE over IPSec、IPSec over GRE或SVTI,其中最主要的原因是IPSec不支持组播传输,无法实现动态路由之间的...【详细内容】
2020-11-10  Tags: 动态路由  点击:(406)  评论:(0)  加入收藏
前言当我们的网关Gateway程序开发完成之后,需要部署到生产环境,这个时候你的程序不能是单点运行的,肯定是多节点启动(独立部署或者docker等容器部署),防止单节点故障导致整个服...【详细内容】
2020-10-19  Tags: 动态路由  点击:(101)  评论:(0)  加入收藏
一、网络拓扑 二、 OSPF关键配置R1 OSPF配置:router ospf 1router-id 1.1.1.1network 10.1.12.0 0.0.0.255 area 0network 12.1.1.0 0.0.0.255 area 0network 192.168.10.0 0...【详细内容】
2020-09-02  Tags: 动态路由  点击:(245)  评论:(0)  加入收藏
FRRouting(FRR)简介FRR 是一个路由软件套件,它衍生自 Quagga,并在 GNU GPL2 许可下分发。与 Quagga 一样,它为类 Unix 平台提供了所有主要路由协议的实现,例如 OSPF、 路由信息协...【详细内容】
2020-06-03  Tags: 动态路由  点击:(582)  评论:(0)  加入收藏
一、OSPF简介OSPF(Open Shortest Path First,开放最短路径优先)是 IETF(Internet Engineering Task Force,互联网工程任务组)组织开发的一个基于链路状态的内部网关协议。目前针对...【详细内容】
2020-03-05  Tags: 动态路由  点击:(136)  评论:(0)  加入收藏
一、OSPF HelloA、OSPF Hello协议的目的:1.用于发现邻居2.在成为邻居之前,必须对Hello包里的一些参数协商成功3.Hello包在邻居之间扮演着keepalive的角色4.允许邻居之间的双...【详细内容】
2019-11-18  Tags: 动态路由  点击:(96)  评论:(0)  加入收藏
一、多区域 OSPF在一个大型 OSPF 网络中,SPF 算法的反复计算,庞大的路由表和拓扑表的维护以及 LSA的泛洪等都会占用路由器的资源,因而会降低路由器的运行效率。OSPF 协议可以利...【详细内容】
2019-11-14  Tags: 动态路由  点击:(139)  评论:(0)  加入收藏
一 、OSPF原理及配置​OSPF(Open Shortest Pass First,开放最短路径优先协议),是一个最常用的内部网关协议,是一个链路状态协议。二 、OSPF的特点 OSPF是一种无类路由协议,支持VL...【详细内容】
2019-11-01  Tags: 动态路由  点击:(189)  评论:(0)  加入收藏
回顾IP路由的概念 在一个IP网络中,路由(Routing)是个非常非常基本的概念。网络的基本功能,是使得处于网络中的两个IP节点能够互相通信,而通信实际上就是数据交互的过程,数据交互则...【详细内容】
2019-06-17  Tags: 动态路由  点击:(479)  评论:(0)  加入收藏
▌简易百科推荐
HTTP 报文是在应用程序之间发送的数据块,这些数据块将通过以文本形式的元信息开头,用于 HTTP 协议交互。请求端(客户端)的 HTTP 报文叫做请求报文,响应端(服务器端)的叫做响应...【详细内容】
2021-12-27  程序员蛋蛋    Tags:HTTP 报文   点击:(0)  评论:(0)  加入收藏
一 网络概念:1.带宽: 标识网卡的最大传输速率,单位为 b/s,比如 1Gbps,10Gbps,相当于马路多宽2.吞吐量: 单位时间内传输数据量大小单位为 b/s 或 B/s ,吞吐量/带宽,就是网络的使用率...【详细内容】
2021-12-27  码农世界    Tags:网络   点击:(2)  评论:(0)  加入收藏
1.TCP/IP 网络模型有几层?分别有什么用? TCP/IP网络模型总共有五层 1.应用层:我们能接触到的就是应用层了,手机,电脑这些这些设备都属于应用层。 2.传输层:就是为应用层提供网络...【详细内容】
2021-12-22  憨猪哥08    Tags:TCP/IP   点击:(29)  评论:(0)  加入收藏
TCP握手的时候维护的队列 半连接队列(SYN队列) 全连接队列(accepted队列)半连接队列是什么?服务器收到客户端SYN数据包后,Linux内核会把该连接存储到半连接队列中,并响应SYN+ACK报...【详细内容】
2021-12-21  DifferentJava    Tags:TCP   点击:(9)  评论:(0)  加入收藏
你好,这里是科技前哨。 随着“元宇宙”概念的爆火,下一代互联网即将到来,也成了互联网前沿热议的话题,12月9日美国众议院的听证会上,共和党议员Patrick McHenry甚至宣称,要调整现...【详细内容】
2021-12-17  王煜全    Tags:Web3   点击:(14)  评论:(0)  加入收藏
一、demopublic static void main(String[] args) throws Exception { RetryPolicy retryPolicy = new ExponentialBackoffRetry( 1000, 3);...【详细内容】
2021-12-15  程序员阿龙    Tags:Curator   点击:(20)  评论:(0)  加入收藏
一、计算机网络概述 1.1 计算机网络的分类按照网络的作用范围:广域网(WAN)、城域网(MAN)、局域网(LAN);按照网络使用者:公用网络、专用网络。1.2 计算机网络的层次结构 TCP/IP四层模...【详细内容】
2021-12-14  一口Linux    Tags:网络知识   点击:(30)  评论:(0)  加入收藏
无论是在外面还是在家里,许多人都习惯了用手机连接 WiFi 进行上网。不知道大家有没有遇到过这样一种情况, 明明已经显示成功连接 WiFi,却仍然提示“网络不可用”或“不可上网”...【详细内容】
2021-12-14  UGREEN绿联    Tags:WiFi   点击:(25)  评论:(0)  加入收藏
拉了千兆宽带,买了标称 1300Mbps 的无线路由器,为什么 WiFi 还是跑不满千兆?要回答这个问题,我们先得知道这个 1300Mbps 是怎么来的。开始回答之前先说明一下,这期只讲 802.11ac,...【详细内容】
2021-12-14  Ubiquiti优倍快    Tags:WiFi   点击:(83)  评论:(0)  加入收藏
问题背景IPv6环境下,在浏览器中通过http://[vip:port]访问web业务,提示无法访问此网站,[vip]的响应时间过长。分析过程之前碰到过多次在PC浏览器上无法访问vip的情况,排查方法也...【详细内容】
2021-12-13  云原生知识星球    Tags:网络问题   点击:(27)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条