Service Discovery in Microservices 客户端/服务端服务发现

原文链接 Client Side Service Discovery in Microservices - GeeksforGeeks

原文链接 Server Side Service Discovery in Microservices - GeeksforGeeks

目录

服务发现介绍

Server-Side 服务发现

实例:

Client-Side 服务发现

实例:

服务发现介绍

服务发现(Service Discovery)就是通过服务名去找服务地址(如 IP和端口)的过程。

去哪里找?当然是去拥有服务器地址信息的组件中找, 这个组件就是 发现服务(Discovery Service)。

发现服务(Discovery Service)哪来的这些地址信息? 每一个微服务启动的时候主动注册上去的。

这些地址信息可以存在一个特定的map,list 或数据库里。

假设我们现在有一个 Service-A, 四个不同地址的Service-B,在启动的时候注册自己的IP和端口到 发现服务(Discovery Service)中, 则信息如下图所示。

当 Service-A 准备调用 Service-B时,首先请求发送到 load balancer(LB), 然后LB去发现服务(Discovery Service)查询 Service-B的地址,结果发现有四个 Service-B。LB只需要按照设置的算法分发给其中一个 Service-B。

具体算法可以看这篇 What is load balancing? 什么是负载均衡?-CSDN博客

Server-Side 服务发现

其实上面这种就是 服务端(Service-Side)的服务发现。具体步骤如下:

1,客户端(Service-A)向服务器发出请求,服务器可能是路由器(Router)、负载平衡器(Load Balancer)或中间人(Middleman)。在本例中,它是一个负载均衡器(Load Balancer)。

2,服务器(负载均衡器)使用发现服务(Discovery Service)执行查询。

3,发现服务(Discovery Service)响应负载均衡器(Load Balancer)可以调用的 Service-B 实例的可用数量。

4,然后负载均衡器服务器(Load Balancer) 拿起一个 Service-B 实例并进行调用。

5,这里,Service-A(客户端)不直接与发现服务(Discovery Service)通信。它调用另一个服务器(负载均衡器)来帮助发现Service-B的URL信息。

这个完整的模式我们称之为服务器端发现。

优点:

        在这种方法中,负载平衡器(Load Balancer)完成负载平衡的工作。这是这种方法的主要优点。毫无疑问,开发这种级别的抽象使服务消费者更加轻量级,因为它不需要处理查找过程。因此,不需要为服务消费者使用的每种语言和框架单独实现发现逻辑。

缺点:

        缺点是我们必须设置和操作负载平衡器(Load Balancer),除非部署环境已经提供了它。

实例:

        Nginx: Nginx是一个web服务器,也可以用作反向代理,负载均衡器,邮件代理和HTTP缓存。Nginx是一个免费的开源软件。
        AWS ELB:弹性负载平衡器(Elastic Load Balancer, ELB)是Amazon提供的一项服务,在该服务中,传入流量以提高速度和性能的方式在一组后端服务器之间高效、自动地分布。它有助于提高应用程序的可伸缩性并保护应用程序。        

Client-Side 服务发现

客户端的服务发现其实就是 Service-A想要调用Service-B,直接请求发现服务,发现服务返回Service-B的四个实例地址,然后负载均衡由客户端Service-A 决定。

优点:对于服务端来说,少了一个额外的跳跃(hop)。

缺点:客户端要自己实现Load Balancing 逻辑。

实例:

        Netflix Eureka:Eureka 是Netflix服务发现服务器和客户端。可以将服务器配置和部署为高可用性,每个服务器将已注册服务的状态复制到其他服务器。

        Zookeeper: Zookeeper是一个分布式、开源的分布式应用协调服务(coordination service)。它公开了一组简单的原语,用于实现用于同步、配置维护、分组和命名的高级服务。

        Consul: Consul是一个服务网络解决方案,用于自动执行网络配置、发现服务,并支持跨任何云或运行时的安全连接。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/492740.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

概率论得学习和整理27:关于离散的数组 随机变量数组的均值,方差的求法3种公式,思考和细节。

目录 1 例子1:最典型的,最简单的数组的均值,方差的求法 2 例子1的问题:例子1只是1个特例,而不是普遍情况。 2.1 例子1各种默认假设,导致了求均值和方差的特殊性,特别简单。 2.2 我觉得 加权…

深度学习之超分辨率算法——SRGAN

更新版本 实现了生成对抗网络在超分辨率上的使用 更新了损失函数,增加先验函数 SRresnet实现 import torch import torchvision from torch import nnclass ConvBlock(nn.Module):def __init__(self, kernel_size3, stride1, n_inchannels64):super(ConvBlock…

基于微信小程序的短视频系统(SpringBoot)+文档

💗博主介绍💗:✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示:文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

【系统】Mac crontab 无法退出编辑模式问题

【系统】Mac crontab 无法退出编辑模式问题 背景一、问题回答1.定位原因:2.确认编辑器类型3.确保编辑器进入正确3.1 确认是否有crontab调度任务3.2 进入编辑器并确保编辑器正常3.3 保存操作 4.确认crontab任务存在5.确保脚本的可执行性和正确性 二、后续 背景 之前…

Java-30 深入浅出 Spring - IoC 基础 启动IoC 纯XML启动 Bean、DI注入

点一下关注吧!!!非常感谢!!持续更新!!! 大数据篇正在更新!https://blog.csdn.net/w776341482/category_12713819.html 目前已经更新到了: MyBatis&#xff…

Restaurants WebAPI(一)—— clean architecture

文章目录 项目地址一、Restaurants.Domain 核心业务层1.1 Entities实体层1.2 Repositories 数据操作EF的接口二、Restaurants.Infrastructure 基础设施层2.1 Persistence 数据EF CORE配置2.2 Repositories 数据查询实现2.3 Extensions 服务注册三、Restaurants.Application用例…

LabVIEW中的“Synchronize with Other Application Instances“

在LabVIEW中,“Synchronize with Other Application Instances”是一个常见的提示或错误,通常出现在尝试并行运行多个LabVIEW实例时,特别是当你打开多个VI或项目时。这个问题可能影响程序的执行流程,导致不同实例之间的数据同步或…

vsCode 报错[vue/no-v-model-argument]e‘v-model‘ directives require no argument

在vue3中使用ui库中的组件语法v-model:value时会提示[vue/no-multiple-template-root]The template root requires exactly one element. 引入组件使用单标签时会提示[vue/no-multiple-template-root]“The template root requires exactly one element. 原因: 1.可…

气象与旅游之间的关系,如果借助高精度预测提高旅游的质量

气象与旅游之间存在密切的关系,天气条件直接影响旅游者的出行决策、旅游体验和安全保障。通过高精度气象预测技术,可以有效提升旅游质量,为游客和旅游行业带来显著的优势。 1. 提高游客出行决策效率 个性化天气服务:基于高精度气象预测,旅游平台可以提供个性化的天气预报服…

vue+springboot+cas配置及cookie传递问题

cookie的注意事项 前边的文章已经介绍过cookie的基本信息,这里再次说明一点:cookie是无法进行跨域传递的,很多时候cookie无法设置和传递都是因为跨域问题,ip/端口不一致。 主要就是:被设置cookie和要传递cookie的地址…

python总说的cd是什么

以下适用于windows环境 cd就是change directory的缩写,即改变目录。 讲cd命令之前,先来看看提示符是什么意思。现在的提示符是c:\> c:说明现在的工作盘是c盘,\告诉我们当前的工作目录是根目录。 >的作用是把工作目录和我们要输入的…

【记录50】uniapp安装uview插件,样式引入失败分析及解决

SassError: Undefined variable: "$u-border-color". 表示样式变量$u-border-color没定义&#xff0c;实际是定义的 首先确保安装了scss/sass 其次&#xff0c;根目录下 app.vue中是否全局引入 <style lang"scss">import /uni_modules/uview-ui/in…

Webpack简单介绍及安装

一、介绍 Webpack 是一个现代 JavaScript 应用程序的静态模块打包器&#xff08;module bundler&#xff09;。它将应用程序中的所有依赖项&#xff08;JavaScript、图片、CSS 等&#xff09;打包成一个或多个 bundle。这样做的主要目的是减少加载时间和提高应用程序的加载性能…

vscode不同的项目使用不同的环境变量或编译环境

转载请标明出处&#xff1a;小帆的帆的博客 假如电脑中安装的两套C编译环境&#xff0c;想要切换编译环境时可以在操作系统的环境变量中调整顺序&#xff0c;然后排在前面的环境就会被使用。 这样做的弊端&#xff1a; 麻烦容易忘&#xff0c;忘了项目不报错就可能就不会发现…

汽车IVI中控开发入门及进阶(三十九):ADAS的车道线检测

概述: 自动驾驶汽车中确保驾驶员和乘客安全环境的重要系统之一是高级驾驶员辅助系统(ADAS)。自适应巡航控制、自动制动/转向、车道保持系统、盲点辅助、车道偏离警告系统和车道检测都是ADAS的示例。车道检测向车辆的智能系统显示特定于车道线结构几何特征的信息,以显示车道…

在Win11系统上安装Android Studio

诸神缄默不语-个人CSDN博文目录 下载地址&#xff1a;https://developer.android.google.cn/studio?hlzh-cn 官方安装教程&#xff1a;https://developer.android.google.cn/studio/install?hlzh-cn 点击Next&#xff0c;默认会同时安装Android Studio和Android虚拟机&#…

如何在 Ubuntu 22.04 上安装 MySQL

简介 MySQL 是开发人员最常用的数据库之一&#xff0c;因为它在功能、性能和易用性之间取得了平衡&#xff0c;提供了高性能、可扩展性、安全性、灵活性和低成本。在本教程中&#xff0c;我们将向您展示如何在七个步骤中在 Ubuntu 22.04 上安装 MySQL。我们包括安装、配置、保…

使用Dynadot API确定当前是否有正在执行中的请求

前言 Dynadot是通过ICANN认证的域名注册商&#xff0c;自2002年成立以来&#xff0c;服务于全球108个国家和地区的客户&#xff0c;为数以万计的客户提供简洁&#xff0c;优惠&#xff0c;安全的域名注册以及管理服务。 Dynadot平台操作教程索引&#xff08;包括域名邮箱&…

02、服务器的分类和开发项目流程

硬件介绍 1、服务器分类2.开发流程 1、服务器分类 1.1 服务器分类 1u服务器&#xff08;u表示服务器的厚度&#xff09; 1U4.45cm&#xff1b; 4u服务器&#xff08;u表示服务器的厚度&#xff09; &#xff0c; 服务器有两个电源模块&#xff0c;接在不同的电源&#xff0c;…

[创业之路-199]:《华为战略管理法-DSTE实战体系》- 3 - 价值转移理论与利润区理论

目录 一、价值转移理论 1.1. 什么是价值&#xff1f; 1.2. 什么价值创造 &#xff08;1&#xff09;、定义 &#xff08;2&#xff09;、影响价值创造的因素 &#xff08;3&#xff09;、价值创造的三个过程 &#xff08;4&#xff09;、价值创造的实践 &#xff08;5&…