Gateway 网关服务

为什么需要网关

网关功能:

  • 对用户请求做身份认证、权限校验
  • 将用户请求路由到微服务,并实现负载均衡
  • 对用户请求做限流

网关的技术实现

 在SpringCloud中网关的实现包括两种:

  • gateway
  • zuul

Zuul是基于Servlet的实现,属于阻塞式编程。而SpringCloudGateway则是基于Spring5中提供的WebFlux,属于响应式编程的实现,具备更好的性能

搭建网关服务

1、创建新的module,引入SpringCloudGateway的依赖和nacos的服务发现依赖:

<!--网关依赖-->
<dependency>   
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!--nacos服务发现依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> 
</dependency>

2、编写路由配置及nacos地址

server:
  port: 10010 # 网关端口
spring:
  application:
    name: gateway # 服务名称
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos地址
    gateway:
      routes: # 网关路由配置
        - id: user-service # 路由id,自定义,只要唯一即可
          # uri: http://127.0.0.1:8081 # 路由的目标地址 http就是固定地址
          uri: lb://userservice # 路由的目标地址 lb就是负载均衡,后面跟服务名称
          predicates: # 路由断言,也就是判断请求是否符合路由规则的条件
            - Path=/user/** # 这个是按照路径匹配,只要以/user/开头就符合要求

网关是个独立的服务,因此需要配置一个端口然后要配置

配置nacos,实现服务的注册和发现

允许有多个路由配置routes,每个路由配置只能有一个路由id

uri是路由的目的地址,可以直接写死目的地址,如 uri: http://127.0.0.1:8081,但是一般不这么使用

一般使用 uri: lb://userservice 这里的 userservice 是注册在服务注册中心的服务,因此上面需要配置nacos

那我们要将哪些请求转发到 userservice服务呢?这个就需要我们配置路由断言,路由断言判断哪些请求需要进行转发,我们这边只进行了Path断言条件,实际上还有很多,我额外写了一篇博客,大家可以参考

http://t.csdn.cn/LRWlXhttp://t.csdn.cn/LRWlX

网关原理

当我们要访问一个具体服务时,不再访问其端口,而是访问网关服务的端口,网关就会将我们的请求再转发给对应的具体服务,如下

 而网关具体就通过注册中心进行远程调用,如下

过滤器 

GatewayFilter是网关中提供的一种过滤器,可以对进入网关的请求和微服务返回的响应做处理

其作用时机如下

我写了另外一篇博客,关于GatewayFilter,有需要的可以点击下方连接

http://t.csdn.cn/XAYi4http://t.csdn.cn/XAYi4

### Gateway网关服务启动后自动闪退的原因分析 Gateway网关服务启动后自动闪退可能是由多种原因引起的,以下是常见的几个方面以及对应的解决方案: #### 1. **端口冲突** 如果网关服务使用的端口已经被其他程序占用,则可能导致服务无法正常绑定端口并立即退出。可以通过运行网络端口测试工具验证是否存在端口冲突[^2]。 - 解决方案: 修改网关服务的配置文件,调整其监听端口号为未被占用的端口。例如,在Spring Cloud Gateway中,可以在`application.yml`或`application.properties`中设置如下参数: ```yaml server: port: 8081 # 更改为未被占用的端口 ``` #### 2. **依赖服务不可用** 某些情况下,网关服务可能依赖于其他微服务(如Redis、Consul、Kafka等)。如果这些依赖的服务未能正常启动或者网络连接存在问题,也可能导致网关服务启动失败。 - 解决方案: 确保所有依赖的服务均已正确启动,并通过健康检查确认它们的状态良好。可以尝试重新启动相关服务,或者排查网络连通性问题。对于Redis为例,可使用以下命令检测其状态: ```bash redis-cli ping ``` 如果返回`PONG`,说明Redis服务可用;否则需进一步排查Redis的日志文件。 #### 3. **配置文件错误** 网关服务的配置文件可能存在语法错误或其他不兼容项,这也会引发服务启动失败的情况。特别是当涉及到复杂的路由规则或过滤器定义时,容易出现此类问题。 - 解决方案: 检查`application.yml`或`application.properties`中的配置是否正确无误。重点关注以下几个部分: - 路由规则定义是否合法; - 是否存在拼写错误或缩进不当等问题; - 敏感字段(如密码)是否填写正确。 示例代码片段展示如何定义简单的路由规则: ```yaml spring: cloud: gateway: routes: - id: example_route uri: http://example.com predicates: - Path=/example/** ``` #### 4. **日志分析不足** 很多时候,网关服务启动失败的具体原因是隐藏在日志中的。如果没有仔细阅读日志信息,可能会忽略重要的调试线索。 - 解决方案: 查看网关服务的标准输出日志和错误日志,定位具体的异常堆栈信息。通常,日志路径位于项目的根目录下,默认名称为`spring.log`或类似的命名方式。如果发现类似“Connection refused”这样的提示,应优先考虑网络层面的因素。 --- ### 总结 针对Gateway网关服务启动后自动闪退的问题,可以从以上四个方面逐一排查。具体操作建议先从最简单易行的部分入手,比如更改默认端口或核对基本配置,再逐步深入至复杂场景下的依赖关系梳理与日志解析过程。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值