spring gateway配合nacos实现负载均衡

1,注册服务到nacos

首先让所有服务都能被nacos给发现,具体教程:整合spring cloud+nacos

2,搭建gateway服务

然后我们建立一个服务,并引入spring gateway相关依赖

xml 复制代码
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-loadbalancer</artifactId>
        </dependency>

⚠️ 重要 :Gateway必须使用WebFlux模型,若项目中存在spring-boot-starter-web依赖,需移除:

webflux和webmvc两套系统是冲突的。

3,配置路由规则

我们在配置文件中写上相应的路由配置,假设我们已经配置了一个名为demo的服务

yml 复制代码
    gateway:
      routes:
        - id: demo
          uri: lb://demo
          predicates:
            - Path=/demo/**
          filters:
            - StripPrefix=1

其中,lb: 这个配置代表负载均衡,StripPrefix 代表要去掉的地址数,意味着在我进行路由转发的时候要去掉/demo。

4. 多实例负载均衡测试

接下来我们在idea里面找到服务列表,右键现有demo服务->编辑所选配置->修改选项->允许多个实例

再编辑这个实例的配置,用同样的找到添加虚拟机选项设置,并写上-Dserver.port=新端口号,我们就有两台同样的服务了。

我的网关服务部署在8888端口,我们提前写好相关接口/user/test

接下来我来访问4次http://localhost:8888/demo/user/test

可以看到两台服务各打印了两次

相关推荐
艾菜籽2 小时前
Spring MVC练习:留言板
java·spring·mvc
摇滚侠2 小时前
Spring Boot 3零基础教程,WEB 开发 自定义静态资源目录 笔记31
spring boot·笔记·后端·spring
左灯右行的爱情2 小时前
4-Spring SPI机制解读
java·后端·spring
橘子海全栈攻城狮3 小时前
【源码+文档+调试讲解】基于SpringBoot + Vue的知识产权管理系统 041
java·vue.js·人工智能·spring boot·后端·安全·spring
kkkkk0211064 小时前
微服务学习笔记(黑马商城)
java·spring boot·spring·spring cloud·sentinel·mybatis·java-rabbitmq
阿里云云原生4 小时前
零代码改造 + 全链路追踪!Spring AI 最新可观测性详细解读
spring·云原生
数智顾问4 小时前
Flink ProcessFunction 与低层级 Join 实战手册:多流广告计费精确去重
java·spring boot·spring
Java水解5 小时前
【Spring】Spring事务和事务传播机制
后端·spring
白露与泡影6 小时前
BAT 大厂 java高频面试题汇总:JVM+Spring+ 分布式 +tomcat+MyBatis
java·jvm·spring
洛克大航海6 小时前
5-SpringCloud-服务链路追踪 Micrometer Tracing
后端·spring·spring cloud·zipkin·micrometer