WHAT - 简单服务发现

文章目录

  • 简单理解
  • 举个例子
  • 简单服务发现方式
    • [1. 静态配置(最简单,但不灵活)](#1. 静态配置(最简单,但不灵活))
    • [2. DNS 发现](#2. DNS 发现)
    • [3. 使用服务注册中心(稍高级)](#3. 使用服务注册中心(稍高级))
  • 总结

"简单服务发现"(Simple Service Discovery)通常指的是一种让系统中的服务自动找到彼此 的机制,特别在 微服务架构分布式系统 中非常常见。

简单理解

服务发现就像一个"电话本"或"联系人列表",让服务A知道如何找到服务B,而不需要硬编码IP或端口。

举个例子

假设你有两个服务:

  • 用户服务(User Service)
  • 订单服务(Order Service)

订单服务需要请求用户服务的数据,但用户服务的 IP 地址可能会变化(比如在容器环境中重启后)。

这时候就需要 服务发现系统 来告诉订单服务:"用户服务现在在这里"。

简单服务发现方式

1. 静态配置(最简单,但不灵活)

直接在配置文件里写死服务的地址:

yaml 复制代码
userService: http://192.168.1.10:8080

缺点:服务 IP 变了就要手动更新。

2. DNS 发现

服务注册在一个域名下,通过 DNS 查找:

bash 复制代码
curl http://user-service.default.svc.cluster.local

常用于 Kubernetes。

3. 使用服务注册中心(稍高级)

服务启动时自动向注册中心注册自己的地址:

  • 注册中心:Consul、Eureka、etcd、Zookeeper

  • 查询流程:

    1. 服务A向注册中心注册:我在 10.0.0.1:8080
    2. 服务B查询注册中心:用户服务在哪?
    3. 注册中心返回地址:10.0.0.1:8080

这种方式可以动态感知服务上下线,更适合大型系统。

总结

类型 描述 适合场景
静态配置 写死服务地址 小型项目、测试
DNS 服务发现 通过服务名称解析 Kubernetes 等平台
注册中心服务发现 服务自动注册和发现 微服务架构、大型系统
相关推荐
笨手笨脚の2 天前
微服务核心
微服务·架构·服务发现·康威法则
Zz_waiting.4 天前
服务注册 / 服务发现 - Eureka
spring cloud·云原生·eureka·服务发现
morning_sir_jking5 天前
深入解析 kube-proxy:Kubernetes 服务发现的网络基石
网络·kubernetes·服务发现
潇凝子潇12 天前
在使用Nacos作为注册中心和配置中心时,如何解决服务发现延迟或配置更新不及时的问题
开发语言·python·服务发现
yunmi_14 天前
微服务,Spring Cloud 和 Eureka:服务发现工具
java·spring boot·spring cloud·微服务·eureka·架构·服务发现
唐僧洗头爱飘柔952714 天前
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
spring cloud·微服务·zookeeper·eureka·服务发现·集群部署·服务注册
Achou.Wang19 天前
kube-prometheus监控服务发现
服务发现·prometheus
Vahala0623-孔勇19 天前
服务发现与注册中心设计:从Eureka到Nacos的CAP权衡——AP与CP的边界,藏在服务列表的一致性里
云原生·eureka·服务发现
绝顶少年19 天前
[特殊字符]️ Spring Cloud Eureka 三步通:搭建注册中心 + 服务注册 + 服务发现,通俗易懂!
spring cloud·eureka·服务发现
一叶飘零_sweeeet2 个月前
从 0 到 1 吃透 Nacos:服务发现与配置中心的终极实践指南
java·分布式·服务发现