微服务网关初体验

概念

微服务网关是微服务架构中的前端门户,它提供了一个统一的入口点,方便客户端访问和调用多个微服务。作为介于客户端和服务器端之间的中间层,微服务网关负责处理所有外部请求,并根据路由规则将其转发到相应的内部服务。

架构

依赖

网关也是一个微服务 。

引入网关依赖,服务注册发现依赖,网关微服务不需要web相关的依赖

路由

写死版

  • yml文件配置
  • 硬编码

根据微服务名动态路由

断言

Predicate就是根据规则去匹配路由

如果有多个路由符合规则,网关会按照配置文件的顺序从上往下匹配,匹配到就返回;进入过滤链过滤

设置路由多久生效

要求携带cookie

要求请求头参数符合正则表达式

剩余

过滤

有过滤链,可以在前后插入逻辑,比如鉴权、日志、限流。

自定义过滤器

创建过滤器类,实现GlobalFilter,Ordered接口,加组件注解。order的值越小,优先级越高。

一个请求进入微服务的流程

一个请求从客户端发来,首先进入nginx反向代理,会进行初步负载均衡等,然后到网关,网关是客户端请求的统一入口,负责根据配置找到具体处理的微服务名(先经过断言匹配路由,再经过过滤器),然后去注册中心获取该服务可用的实例(或者网关定时拉取服务可用列表),然后根据负载均衡算法选一个实例发送请求。请求到了微服务A之后,可能需要调用服务B,这个时候服务A向注册中心发送一个服务调用请求,一般包含服务名,注册中心返回能用的服务B实例列表,服务A根据负载均衡算法,选择一个服务B实例发送请求。

微服务之间如果请求失败,负载均衡组件可能还有重试机制,提高了服务的容错性。如ribbon

网关也有重试机制,并且网关还可以实现反向代理,鉴权,限流,熔断,日志监控等

服务A请求服务B的某个实例的时候会尝试建立连接,有可能建立连接超时,服务A就知道该实例不可用,然后根据负载均衡请求另一个实例。如果一个可用的服务都没有,会返回服务不可用提示,而不会返回404.

相关推荐
杀死那个蝈坦1 分钟前
短链接生成-基于布隆过滤器和唯一索引
java·数据库·微服务·oracle·rocketmq
慕白Lee1 分钟前
Java foreach在lambda的foreach遍历中退出操作(lambda foreach break)
java
winfield8214 分钟前
Java 中大量闲置 MySQL 连接的解决方案(从根因到落地)
java·mysql
moxiaoran57536 分钟前
Java开发中VO的使用
java·开发语言
计算机毕设指导67 分钟前
基于微信小程序图像识别的智能垃圾分类系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·分类·maven
LJianK113 分钟前
前后端接口常见传参
java·spring
独自破碎E15 分钟前
消息队列如何保证消息的有效性?
java·开发语言·rocketmq·java-rocketmq
38242782716 分钟前
使用 webdriver-manager配置geckodriver
java·开发语言·数据库·爬虫·python
骚戴23 分钟前
2025企业级架构演进:重构 Java/Python 的 RAG 与 Agent 系统的六种核心策略
java·人工智能·大模型·llm·api
悟空码字30 分钟前
SpringBoot读取Excel文件,一场与“表格怪兽”的搏斗记
java·spring boot·后端