草庐IT

关于Spring cloud Gateway集成nacos 实现路由到指定微服务的方式总结

Austinu 2024-04-25 原文

项目地址

Nacos

两种方式实现nacos服务注册与发现

Nacos服务注册与发现的2种实现方法

1.OpenAPI模式

2.SDK模式

Spring Cloud GateWay

gateway网关路由配置详解

gateway动态配置网关路由规则

微服务路由

方式1,nacos自动下发

应用

请求路径中包含微服务名

例如:查询 微服务 demo-system 下的路由接口列表信息,其中网关微服务的端口是 9999。

http://localhost:9999/demo-system/sys/gatewayRoute/list

应用场景

gateway 微服务路由

配置方式

application.yml

spring:  
  cloud:
    gateway:
      # 此处配置表示开启自动映射naocs下发的路由
      discovery:
        locator:
          enabled: true
          lowerCaseServiceId: true
      default-filters:
  main:
    allow-bean-definition-overriding: true #当遇到同样名字的时候,是否允许覆盖注册

优点

nacos自动下发,和gateway本身无关,路由转发的功能由nacos分担。因此对开发友好,易上手。

缺点

只要是 微服务 demo-system的接口都可以进行请求。请求范围大。

方式2,yml 配置路由规则

应用

gateway 根据路径参数查找 对应的服务进行路由。

例如:查询 微服务 demo-system 下的路由接口列表信息,其中网关微服务的端口是 9999。

http://localhost:9999/sys/gatewayRoute/list

应用场景

jeecg-boot gateway服务路由

配置方式

application.yml

spring:
  cloud:
    gateway:
      # 配置路由规则
      routes:
        # 采用自定义路由 ID(有固定用法,不同的 id 有不同的功能
        - id: demo-business
          # 采用 LoadBalanceClient 方式请求,以 lb:// 开头,后面的是注册在 Nacos 上的服务名
          uri: lb://demo-business
#          uri: http://192.168.0.105:18000
          # Predicate 翻译过来是“谓词”的意思,必须,主要作用是匹配用户的请求,有很多种用法
          predicates:
            - Path=/business/**,/biz/**
            # Method 方法谓词,这里是匹配 GET 和 POST 请求
            - Method=GET,POST

        - id: demo-system
          uri: lb://demo-system
          predicates:
            - Path=/system/**,/sys/**

优点

因为是否能路由到对应的微服务,是根据路由条件进行匹配的,所以这种路由方式更加严格,自定义路由条件配置。路由范围自定义。

缺点

如果出现对路由规则条件配置的变更,活增加新的微服务,都需要停掉网关服务,然后进行配置,再进行部署。比较繁琐。

方式3, 数据库读取路由配置规则

应用

为了解决方式2的缺点,即不停网关服务,依然能进行配置路由规则,并且路由功能生效,这就诞生了数据库动态路由。

动态路由的机制:

1)实现一个Spring提供的事件推送接口ApplicationEventPublisherAware,

2)提供动态路由的基础方法,可通过获取bean操作该类的方法。该类提供新增路由、更新路由、删除路由,然后实现发布的功能。

例如:查询 微服务 demo-system 下的路由接口列表信息,其中网关微服务的端口是 9999。

http://localhost:9999/sys/gatewayRoute/list

应用场景

jeecg-boot 默认 gateway服务路由方式

配置方式

优点

方便集中管理,自定义程度较高。

缺点

需要由webflux基础,上手较难。需要有网关路由条件配置界面。

如果是微服务名不同,匹配路径相同,比如 jeecg-system 和demo-system 微服务 都有查询路由这个路径规则 /sys/**,启动jeecg-system, 停止demo-system,可能会出现找服务找到demo-system,而不是 jeecg-system微服务。从而出现微服务不可用异常。

jeecg-boot 使用自定义 status 来控制 微服务是否可用,而不是根据实际nacos注册中心中注册的微服务实例 来进行判断是否进行路由。

Spring Cloud LoadBalancer

https://blog.csdn.net/feiying0canglang/article/details/126815588

SpringCloud从2020版本开始移除了对Ribbon的依赖,官方使用Spring Cloud Loadbalancer正式替换Ribbon,而且Spring Cloud Loadbalancer成为了Spring Cloud负载均衡器的唯一实现。

方式4, nacos配置路由规则json文件

应用

路由规则配置在 demo-gateway-router.json,然后在demo-gateway-dev.yaml中指定路由规则时nacos。

例如:查询 微服务 demo-system 下的路由接口列表信息,其中网关微服务的端口是 9999。

http://localhost:9999/sys/gatewayRoute/list

应用场景

jeecg-boot 可以选择使用 nacos 路由配置规则,动态刷新路由。

配置方式

demo-gateway-router.json

[{
  "id": "jeecg-system",
  "order": 6,
  "predicates": [{
    "name": "Path",
    "args": {
      "_genkey_0": "/sys/**",
      "_genkey_1": "/jmreport/**",
      "_genkey_3": "/online/**",
      "_genkey_4": "/generic/**"
    }
  }],
  "filters": [],
  "uri": "lb://jeecg-system"
}, {
  "id": "jeecg-demo",
  "order": 1,
  "predicates": [{
    "name": "Path",
    "args": {
      "_genkey_0": "/mock/**",
      "_genkey_1": "/test/**",
      "_genkey_2": "/bigscreen/template1/**",
      "_genkey_3": "/bigscreen/template2/**"
    }
  }],
  "filters": [],
  "uri": "lb://jeecg-demo"
}, {
  "id": "jeecg-system-websocket",
  "order": 2,
  "predicates": [{
    "name": "Path",
    "args": {
      "_genkey_0": "/websocket/**",
      "_genkey_1": "/newsWebsocket/**"
    }
  }],
  "filters": [],
  "uri": "lb:ws://jeecg-system"
}, {
  "id": "jeecg-demo-websocket",
  "order": 3,
  "predicates": [{
    "name": "Path",
    "args": {
      "_genkey_0": "/vxeSocket/**"
    }
  }],
  "filters": [],
  "uri": "lb:ws://jeecg-demo"
},{
  "id": "demo-system",
  "order": 4,
  "predicates": [{
    "name": "Path",
    "args": {
      "_genkey_0": "/sys/**",
      "_genkey_1": "/system/**"
    }
  }],
  "filters": [],
  "uri": "lb://demo-system"
}, {
  "id": "demo-business",
  "order": 5,
  "predicates": [{
    "name": "Path",
    "args": {
      "_genkey_0": "/mock/**",
      "_genkey_1": "/business/**"
    }
  }],
  "filters": [],
  "uri": "lb://demo-business"
}]

优点

易上手。实现动态路由,在nacos修改路由规则后可以不用重启网关,路由生效。

缺点

如果微服务一多,维护可能复杂。

如果是微服务名不同,匹配路径相同,比如 jeecg-system 和demo-system 微服务 都有查询路由这个路径规则 /sys/**,启动jeecg-system, 停止demo-system,可能会出现找服务找到demo-system,而不是 jeecg-system微服务。从而出现微服务不可用异常。

总结

综上所述,作者认为实现spring cloud 动态路由最好的方式是 使用nacos自动下发。

有关关于Spring cloud Gateway集成nacos 实现路由到指定微服务的方式总结的更多相关文章

  1. ruby-on-rails - Rails 3 中的多个路由文件 - 2

    Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题

  2. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  3. ruby-on-rails - 在 ruby​​ .gemspec 文件中,如何指定依赖项的多个版本? - 2

    我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这

  4. ruby - 如果指定键的值在数组中相同,如何合并哈希 - 2

    我有一个这样的哈希数组:[{:foo=>2,:date=>Sat,01Sep2014},{:foo2=>2,:date=>Sat,02Sep2014},{:foo3=>3,:date=>Sat,01Sep2014},{:foo4=>4,:date=>Sat,03Sep2014},{:foo5=>5,:date=>Sat,02Sep2014}]如果:date相同,我想合并哈希值。我对上面数组的期望是:[{:foo=>2,:foo3=>3,:date=>Sat,01Sep2014},{:foo2=>2,:foo5=>5:date=>Sat,02Sep2014},{:foo4=>4,:dat

  5. ruby - 如何根据特征实现 FactoryGirl 的条件行为 - 2

    我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden

  6. ruby-on-rails - 如何使辅助方法在 Rails 集成测试中可用? - 2

    我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel

  7. ruby - 当使用::指定模块时,为什么 Ruby 不在更高范围内查找类? - 2

    我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or

  8. ruby-on-rails - 我如何将 Hoptoad 与 DelayedJob 和 DaemonSpawn 集成? - 2

    我一直很高兴地使用DelayedJob习惯用法:foo.send_later(:bar)这会调用DelayedJob进程中对象foo的方法bar。我一直在使用DaemonSpawn在我的服务器上启动DelayedJob进程。但是...如果foo抛出异常,Hoptoad不会捕获它。这是任何这些包中的错误...还是我需要更改某些配置...或者我是否需要在DS或DJ中插入一些异常处理来调用Hoptoad通知程序?回应下面的第一条评论。classDelayedJobWorker 最佳答案 尝试monkeypatchingDelayed::W

  9. ruby - rails 3 redirect_to 将参数传递给命名路由 - 2

    我没有找到太多关于如何执行此操作的信息,尽管有很多关于如何使用像这样的redirect_to将参数传递给重定向的建议:action=>'something',:controller=>'something'在我的应用程序中,我在路由文件中有以下内容match'profile'=>'User#show'我的表演Action是这样的defshow@user=User.find(params[:user])@title=@user.first_nameend重定向发生在同一个用户Controller中,就像这样defregister@title="Registration"@user=Use

  10. ruby-on-rails - Rails 3,嵌套资源,没有路由匹配 [PUT] - 2

    我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle

随机推荐