微服务中的服务发现与注册中心

news/2025/4/1 5:17:20/

微服务架构中,服务实例的数量可能随着流量负载自动扩展或缩减,因此服务之间如何高效地进行通信成为一个重要问题。本篇博客将介绍服务发现的概念,并结合 Consul自定义注册中心 进行实践,帮助开发者在微服务架构下高效管理服务通信。


1. 什么是服务发现

服务发现是指微服务架构中,服务实例能够被其他服务动态定位的机制。在单体应用中,服务通常运行在固定的 IP 地址和端口上,而在微服务架构中,由于容器化和自动扩展,服务的 IP 和端口可能是动态的,导致传统的静态配置方法不再适用。

服务发现主要分为两种模式:

  1. 客户端服务发现(Client-side Service Discovery):客户端直接查询服务注册中心,获取可用的服务实例列表。

  2. 服务器端服务发现(Server-side Service Discovery):请求先经过负载均衡器或 API 网关,由它负责查询服务实例并转发请求。


2. DNS 作为服务发现方案

DNS(域名系统)是最基础的服务发现机制,它将域名解析为服务器 IP 地址,并可以结合负载均衡来管理多个实例。

DNS 的优势

  • 适用于已有基础设施,不需要额外的服务发现组件。

  • 广泛兼容各类客户端和服务端技术。

DNS 的局限性

  • 更新不够及时:DNS 记录的缓存(TTL)可能导致客户端继续使用失效的 IP 地址。

  • 负载均衡策略有限:默认的 DNS 轮询策略无法动态适应服务状态变化。

解决方案:使用 Consul 作为动态 DNS 解析服务,提供服务注册与发现功能。


3. 通过 Consul 进行服务发现

Consul 是 HashiCorp 开源的一款服务发现与健康检查工具,它支持 DNS 解析和 REST API 查询,能自动感知服务的健康状态。

(1) 启动 Consul

首先,我们需要运行 Consul 作为服务发现中心:

consul agent -dev

然后打开浏览器访问 http://127.0.0.1:8500,查看 Consul 控制台。

(2) 注册服务到 Consul

创建 loginService.js,作为待注册的微服务

const express = require('express');
const app = express();app.get('/health', (req, res) => {res.status(200).send('OK');
});app.listen(3000, () => {console.log('loginService 运行在 http://127.0.0.1:3000');
});

然后创建 loginServiceRegister.js,将 loginService 注册到 Consul:

const consul = require('consul')({ host: '127.0.0.1', port: 8500 });const serviceId = 'login-service-3000';consul.agent.service.register({id: serviceId,name: 'loginService',address: '127.0.0.1',port: 3000,check: {http: 'http://127.0.0.1:3000/health',interval: '10s'}
}, (err) => {if (err) {console.error('服务注册失败:', err);} else {console.log('loginService 注册成功');}
});

运行:

node loginService.js
node loginServiceRegister.js

可以在 Consul 控制台 http://127.0.0.1:8500 查看注册的服务。

(3) 服务健康检查

在 Consul 中,健康检查服务发现的重要部分。健康检查的作用包括:

  • 确保服务正常运行。

  • 发现故障时自动从可用实例列表中移除该服务。

loginService 停止时,Consul 控制台会标记它为 critical,并在恢复运行后自动恢复 healthy 状态。


4. 自定义注册中心实现

除了使用 Consul 作为注册中心,我们还可以手动实现一个轻量级的服务注册中心,适用于不需要完整 Consul 功能的项目

(1) 目录结构

microservices/├── registry-service/  # 服务注册中心├── catalog-service/   # 目录服务├── shopper-service/   # 购物者前端

(2) 搭建注册中心

  1. 初始化注册中心项目

mkdir registry-service && cd registry-service
npm init -y
npm install express axios
  1. 创建 registry-service/index.js,提供服务注册 API:

const express = require('express');
const app = express();
app.use(express.json());let services = {};app.post('/register', (req, res) => {const { name, version, ip, port } = req.body;const serviceKey = `${name}-${version}`;services[serviceKey] = { ip, port, lastUpdated: Date.now() };console.log(`已注册: ${serviceKey} -> ${ip}:${port}`);res.send({ message: '服务注册成功' });
});app.get('/discover/:name/:version', (req, res) => {const serviceKey = `${req.params.name}-${req.params.version}`;res.send(services[serviceKey] || {});
});setInterval(() => {const now = Date.now();for (const key in services) {if (services[key].lastUpdated < now - 60000) {delete services[key];console.log(`移除过期服务: ${key}`);}}
}, 60000);app.listen(4000, () => console.log('注册中心运行在 http://127.0.0.1:4000'));

5. 总结

本篇博客介绍了服务发现的基本概念,并分别使用 Consul 和自定义注册中心 进行了实现,同时增加了健康检查和过期服务清理功能。希望能帮助你在微服务架构中更好地管理服务注册与发现!🚀


http://www.ppmy.cn/news/1583233.html

相关文章

结构型——代理模式

结构型——代理模式 代理模式指的是通过创建一个代理来控制对原始对象的访问。代理在客户端与实际对象之间充当“中介” 特点 访问控制&#xff1a;代理对象可以控制对实际对象的访问&#xff0c;从而实现对访问权限的控制。延迟加载&#xff1a;代理对象可以在实际对象被调…

【C语言】多进程/多线程

【C语言】多进程/多线程 参考链接多进程/多线程服务器1. 多进程服务器2. 多线程服务器 结语参考链接 参考链接 c 中文网 菜鸟 c 多进程/多线程服务器 多进程和多线程是常用的并发编程技术。它们都允许程序同时执行多个任务&#xff0c;提高了系统的资源利用率和程序的运行效率…

git-lfs: command not found

遇到 git-lfs: command not found 错误&#xff0c;表示你的系统中未安装 Git Large File Storage (LFS) 扩展工具。以下是针对不同操作系统的解决方案&#xff1a; 1. 安装 Git LFS 根据你的操作系统选择安装方式&#xff1a; macOS 使用 Homebrew&#xff08;推荐&#xff…

MATLAB 中,并行池(Parallel Pool)自动关闭的情况

在 MATLAB 中&#xff0c;并行池&#xff08;Parallel Pool&#xff09;的行为可以通过设置进行控制&#xff0c;但默认情况下&#xff0c;并行池不会自动关闭&#xff0c;除非满足某些条件或显式调用关闭命令。以下是关于并行池自动关闭机制的详细说明&#xff1a; 自动关闭的…

19926 分球

19926 分球 ⭐️考点&#xff1a;数学、排列组合 &#x1f31f;难度&#xff1a;简单 &#x1f4d6; &#x1f4da; import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner;public class Main {static long[][] dp ne…

盛铂科技SPP5006/18/40G峰值脉冲功率计探头 国产功率计

功率计简述 SPP5000系列是盛铂科技自主开发的自带USB 接口的多功能便携式数字脉冲峰值功率计&#xff0c;可快速执行50MHz至40GHz频率范围和-20dBm至20dBm动态范围的设置和测量&#xff0c;SPP5000系列具备脉冲信号测量与连续波信号测量能力。系统内置等效24Bit 高速采样ADC 并…

小程序跳转到h5页面

本组件使用useState、WebView、Taro的钩子&#xff0c;以及taro-hooks中的useRouter。组件内部使用了useRouter获取路由信息&#xff0c;从存储中获取openId和TOKEN&#xff0c;然后通过useReady生命周期钩子设置URL。分享功能部分使用useShareAppMessage处理&#xff0c;构建分…

关于CNN,RNN,GAN,GNN,DQN,Transformer,LSTM,DBN你了解多少

以下是神经网络中常见的几种模型的简要介绍&#xff1a; 1. ​CNN (Convolutional Neural Network, 卷积神经网络) ​用途: 主要用于图像处理和计算机视觉任务。​特点: 通过卷积核提取局部特征&#xff0c;具有平移不变性&#xff0c;能够有效处理高维数据&#xff08;如图像…