java_网络服务相关_gateway_nacos_feign区别联系

1. spring-cloud-starter-gateway

  • 作用:作为微服务架构的网关,统一入口,处理所有外部请求。
  • 核心能力:
    • 路由转发(基于路径、服务名等)
    • 过滤器(鉴权、限流、日志、Header 处理)
    • 支持负载均衡(结合服务发现)
    • 支持自定义路由规则、熔断(集成 Resilience4j)、降级等

2. spring-cloud-starter-alibaba-nacos-discovery

  • 作用:服务注册与发现中心,每个微服务上线后将自己注册进 Nacos,其他服务通过 Nacos 查找并访问它。
  • 核心能力:
    • 服务注册与发现(类似 Eureka,但更强)
    • 健康检查
    • 动态负载均衡
    • 配合 Feign、RestTemplate 实现服务名访问

3. spring-cloud-starter-alibaba-nacos-config

  • 作用:集中配置中心,所有微服务的配置文件统一托管在 Nacos 中。
  • 核心能力:
    • 支持动态刷新配置(结合@RefreshScope)
    • 多环境配置、共享配置
    • YAML、Properties 格式都支持

|-----------------|------|---------------------|
| 项目 | 功能分类 | 主要用途 |
| gateway | 网关层 | 请求统一入口、路由转发、过滤器、限流等 |
| nacos-discovery | 注册发现 | 服务注册、调用、负载均衡 |
| nacos-config | 配置中心 | 统一配置管理、动态刷新 |

Gateway 是入口,Nacos 是路由图(服务注册表)+ 配置字典,两者一起组成微服务体系的"导航+配置+调用"基础能力。

Nacos ≠ Feign

Nacos 提供"地址簿",Feign 负责"打电话"。

Nacos 是服务发现,Feign 是远程调用。

4. RestTemplate + Ribbon 为何过时?

  • Ribbon

是 Netflix 提供的客户端负载均衡组件,Spring Cloud 在早期版本中默认使用它(和 RestTemplate 搭配)。

  • RestTemplate

虽然还能用,但 Spring 官方已明确表示将在后续版本中弃用,推荐改用 WebClient。

  • Spring Cloud 2020+ 之后已经把 Ribbon 替换成

Spring Cloud LoadBalancer。

📌 官方推荐替代方案:

  • 使用 WebClient + LoadBalancer
  • 或者直接使用 OpenFeign(底层已集成 LoadBalancer)

5. OpenFeign 是什么?还推荐吗?

OpenFeign 是 当前推荐的主流服务调用方式。

作用:

  • 基于接口,自动生成远程调用代码,像调用本地方法一样调用远程服务。
  • 内置支持:
    • 请求参数绑定
    • 请求日志
    • 超时重试
    • 负载均衡(结合 Nacos 服务发现)
相关推荐
SimonKing30 分钟前
基于Netty的TCP协议的Socket服务端
java·后端·程序员
予枫的编程笔记31 分钟前
Elasticsearch深度搜索与查询DSL实战:精准定位数据的核心技法
java·大数据·人工智能·elasticsearch·搜索引擎·全文检索
荒诞硬汉34 分钟前
面向对象(三)
java·开发语言
郝学胜-神的一滴35 分钟前
深入理解Linux中的Try锁机制
linux·服务器·开发语言·c++·程序人生
liliangcsdn36 分钟前
bash中awk如何切分输出
开发语言·bash
柒.梧.37 分钟前
Spring Boot集成JWT Token实现认证授权完整实践
java·spring boot·后端
白露与泡影37 分钟前
放弃 IntelliJ IDEA,转 VS Code 了。。
java·ide·intellij-idea
迷雾骑士39 分钟前
IDEA中将项目提交到Gitee仓库
java·gitee·intellij-idea
菜鸟233号41 分钟前
力扣416 分割等和子串 java实现
java·数据结构·算法·leetcode
csbysj202042 分钟前
JSON.parse() 方法详解
开发语言