004-spring cloud alibaba之gateway网关-负载均衡

gateway负载均衡

主要内容:使用自动负载均衡能力/手动负载均衡。启动多个user服务。让gateway自动选择需要路由到哪个user服务中。这其中有两点需要关心

  • 自动负载能力:一般采用轮询的方式调用user服务
  • gateway查找规则:user服务注册到nacos上gateway会按照注册的服务名称自动映射到对应的服务
    手动负载均衡同样可以实现上面的能力还可以避免暴露nacos服务注册的服务名
  • 自动负载均衡
  • 手动负载均衡

1、gateway自动负载均衡

1.1 启动服务情况

启动两个user服务

服务 端口
user 9001
user 9002
gateway 9999

服务都注册到nacos上面

1.2 gateway配置文件

yaml 复制代码
server:
  port: 9999
spring:
  application:
    name: gateway-service
  cloud:
    nacos:
      discovery:
        server-addr: 10.106.114.1:8848
    gateway:
      discovery:
        locator:
          enabled: true

其中gateway.discovery.locator.enabled=true就是开启自动负载功能。此时如何访问:http://localhost:9999/user/user/hello 就能够自动访问到user服务。前面一个/user/是在找nacos上面的服务,后面一个/user/是我们前面配置的context-path。所以我们可以去掉context-path然后重启user,这样访问路径就变成:http://localhost:9999/user/hello

1.2.1 user服务配置文件变更

变更前

yaml 复制代码
server:
  port: 9001
  servlet:
    context-path: /user/

spring:
  application:
    name: user
  cloud:
    discovery:
      server-addr: 127.0.0.1:8848

management:
  endpoint:
    web:
      exposure:
        include:'*'

变更后

yaml 复制代码
server:
  port: 9001

spring:
  application:
    name: user
  cloud:
    discovery:
      server-addr: 127.0.0.1:8848

management:
  endpoint:
    web:
      exposure:
        include:'*'

这种自动负载会暴露我们nacos注册的服务名字。还可以使用手动负载

2、手动负载均衡

修改gateway配置文件

yaml 复制代码
server:
  port: 9999
spring:
  application:
    name: gateway-service
  cloud:
    nacos:
      discovery:
        server-addr: 10.106.114.1:8848
    gateway:
      discovery:
        locator:
          enabled: false
      routes:
        - id: user
          uri: lb://user
          predicates:
            - Path=/cjxz/**
          filters:
            - StripPrefix=1 # 去掉第一个路径:/cjxz/
management:
  endpoint:
    web:
      exposure:
        include:'*'
相关推荐
stark张宇1 天前
微服务架构必备:Gin + gRPC + Consul + Nacos + GORM 打造用户服务
微服务·gin·grpc
阿里云云原生4 天前
MSE Nacos Prompt 管理:让 AI Agent 的核心配置真正可治理
微服务·云原生
阿里云云原生4 天前
阿里云微服务引擎 MSE 及 API 网关 2026 年 1 月产品动态
微服务
麦聪聊数据5 天前
统一 Web SQL 平台如何收编企业内部的“野生数据看板”?
数据库·sql·低代码·微服务·架构
云司科技codebuddy5 天前
技术支持过硬Trae核心代理
大数据·运维·python·微服务
递归尽头是星辰5 天前
微服务事务分级治理:从 Seata 全模式到 TDSQL 实战
微服务·云原生·架构·分布式事务·事务分级治理
没有bug.的程序员5 天前
订单系统重构史诗:从单体巨兽到微服务矩阵的演进、数据一致性内核与分布式事务
java·微服务·矩阵·重构·分布式事务·数据一致性·订单系统
江西理工大学小杨5 天前
高性能 C++ 社交平台4:基于 Boost.Beast 的 WebSocket 网关实现
c++·websocket·微服务
麦聪聊数据5 天前
数据流通的最后一公里:SQL2API 在企业数据市场中的履约架构实践
数据库·sql·低代码·微服务·架构
知识即是力量ol6 天前
微服务架构:从入门到进阶完全指南
java·spring cloud·微服务·nacos·架构·gateway·feign