12-使用gateway作为微服务网关

本文介绍spring gateway的使用,包括配置文件的使用和调试跟踪,让大家了解spring gateway的基本用法。如果不了解什么是微服务网关,就先查查资料,网关相对来说是比较重要的微服务组件。

0、环境

  • springboot 2.4.2
  • springcloud gateway 3.0.1
  • jdk 1.8

1、创建微服务网关

两个服务,一个是网关,另一个是普通服务。网关用来转发请求,普通服务用来处理对应的请求。项目结构如下图:

下面咱们一起构造这个项目。先创建gateway项目,就是普通maven项目。

1.1、添加依赖

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

1.2、添加配置文件

创建application.yml文件,并添加如下配置:

yml 复制代码
server:
  port: 9080

spring:
  application:
    name: gateway-sample

  cloud:
    gateway:
      discovery:
        locator:
          enabled: true
      routes:
        - id: gateway-02
          uri: http://localhost:9081          #匹配后提供服务的路由地址
          predicates:
            - Path=/sample/service1/say/**         # 断言,路径相匹配的进行路由
          filters:
            - StripPrefix=2

说明:

  • uri:说明要跳转的uri地址
  • StripPrefix:指定要从源地址截取的个数,以"/"为分隔符。以地址栏输入"http://localhost:8080/sample/service1/say/\*\* "为例,域名部分不计,那就是从sample/service1/say/** 计算,StripPrefix=2,表示从前截取两个"/",那么结构就是:/say/**,你的服务必须对应这个uri,否则会出现404。
  • id:随便写,保持和其他服务不同就是了

1.3、启动

springboot启动类就不多说了吧,启动只要没有出错就算是正常。这里唯一要注意的是pom文件里不能引入springboot web依赖,一旦引入启动时就报错。大家注意观察,我们启动gateway时,是netty而不是tomcat。

2、service1 服务编写

service1服务属于普通服务,按照普通springboot服务创建就行。这里注意端口保持和gateway不一样,我这里用9081。注意pom.xml要引入springboot web的依赖。在这里贴出controller的代码:

bash 复制代码
@RestController
@RequestMapping("/say")
public class SomethingToSay {

    @GetMapping("/hello")
    public String sayHello() {
        return "hello";
    }

    @GetMapping("/hi")
    public String sayHi() {
        return "hi";
    }

    @GetMapping("/ohh")
    public String sayOhh() {
        return "ohh";
    }
}

好了,一个带网关的微服务就开发完成了。通关网关uri做一下测试。

http://localhost:9080/sample/service1/say/hello,看结果若是返回了hello表示正常。

3、排错

在通过网关调用后端服务时,出现404,大部分情况都是手抖了,输错了uri,但是大部分同学又排查不细心,认为是gateway的问题,在这里我带大家写个全局Filter,首先确认请求已经到了gateway,如果请求连gateway都没到,那肯定是uri输入错误。这个Filter写在gateway模块里,代码如下:

java 复制代码
@Component
public class MyGlobalFilter implements GlobalFilter, Ordered {

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        System.out.println("服务调用请求:" + exchange.getRequest().getURI());
        return chain.filter(exchange).then(Mono.fromRunnable(() ->
                System.out.println("服务调用返回了," + exchange.getResponse().getStatusCode())));
    }

    @Override
    public int getOrder() {
        return 0;
    }
}

效果如图:

OK,一个简单的网关就开发完成了。

相关推荐
heimeiyingwang5 小时前
【架构实战】设计一个日志分析平台(ELK架构)
elk·架构·linq
企业架构师老王5 小时前
货物入库分类混乱与库位规划难题:基于实在Agent的非侵入式仓储架构演进指南
人工智能·ai·架构
生成论实验室6 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第十七章 科学与人心的重聚
人工智能·算法·架构·知识图谱·创业创新
从零开始学习人工智能6 小时前
一文读懂Safous网关+POP架构:零信任ZTNA完整工作原理(请求+响应全流程)
服务器·网络·架构
不懂的浪漫7 小时前
Netty 不只是 TCP 框架:它解决的是高并发业务系统的组织问题
网络·网络协议·tcp/ip·架构·netty
YJlio7 小时前
OpenClaw v2026.4.8 更新解析:扩展加载修复、通道配置优化、Slack 代理支持与升级避坑
gateway·自动化运维·版本更新·ai agent·openclaw·slack·插件兼容
千帆_Evan7 小时前
agent使用初体验
架构
小短腿的代码世界8 小时前
Qt事件驱动高频交易引擎架构:从事件循环到零延迟通信的完整实现
qt·架构
skilllite作者9 小时前
Deer-Flow 工作流引擎深度评测报告
java·大数据·开发语言·chrome·分布式·架构·rust
摇滚侠9 小时前
Java 项目教程《黑马商城》微服务拆分 20 - 22
java·分布式·架构