注册中心~

注册中心:是服务实例信息的存储仓库,也是服务提供者和服务消费者进行交互的桥梁。它主要提供了服务注册服务发现这两大核心功能。
注册中心可以说是微服务架构中的“通讯录”,它记录了服务和服务地址的映射关系。

常用的注册中心有Zookeeper、Eureka、Nacos、Consul和ETCD等,它们各有特点和区别,适用于不同的场景和需求。

一、Eureka
1.概念:Eureka是Netflix开源的一款提供服务注册和发现的产品,基于Restful API的分布式微服务注册与发现组件,它提供了服务注册和服务发现的能力,使得服务之间可以相互发现和调用。是Spring Cloud体系中最重要最核心的组件之一。

Eureka有两个角色:Eureka Server和Eureka Client。
Eureka Server是注册中心,负责维护服务实例的信息。Eureka Client是服务提供者或消费者,负责向注册中心注册自己或从注册中心获取服务列表。
拓展:@EnableEurekaServer注解
Eureka Server和Eureka Client概念

2.Eureka的相关步骤及状态

  • 创建Eureka Server:首先,你需要创建一个Eureka Server。在你的pom.xml文件中添加Eureka Server的依赖,然后在你的Spring
    Boot应用程序的主类中添加@EnableEurekaServer注解,并运行该类以启动Eureka Server。

  • 创建Eureka Client:接下来,你需要创建一个或多个Eureka Client。在你的pom.xml文件中添加Eureka Client的依赖,然后在你的Spring Boot应用程序的主类中添加@EnableEurekaClient注解,并运行该类以启动Eureka Client。

  • 服务注册:当你的微服务启动时,它会自动将自己注册到Eureka Server。

  • 服务发现:当你的微服务需要调用其他微服务时,它会向Eureka Server请求该服务的信息,然后根据返回的信息来调用该服务。

  • 服务下线:当你的微服务停止时,它会自动从Eureka Server中注销。

  • 服务同步:如果你有多个Eureka Server,它们会相互注册,形成一个服务注册中心集群。当一个服务注册到一个Eureka Server时,该信息会被复制到其他所有的Eureka Server。

  • 服务续约:Eureka Client会定期向Eureka Server发送心跳来续约,表明该服务还在运行。如果Eureka Server在一定时间内没有收到某个服务的心跳,它会注销该服务。

3.实现:
3.1创建Eureka Server关键步骤:

  1. 添加依赖:在pom.xml文件中添加Eureka Server的依赖。
<dependencies>
  <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
  </dependency>
</dependencies>
  1. 配置Eureka Server:在application.ymlapplication.properties文件中配置Eureka Server。
server:
  port: 8761

eureka:
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
  instance:
    hostname: localhost
  1. 启动Eureka Server:在Spring Boot应用程序的主类中添加@EnableEurekaServer注解,并运行该类以启动Eureka Server。
@SpringBootApplication
@EnableEurekaServer
public class EurekaserverApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaserverApplication.class, args);
    }
}

拓展:3.2配置Eureka Server application.yml文件说明:

  • server: port: 8761:Eureka Server运行的端口号,默认端口号:8761。

  • eureka: client: registerWithEureka: false:表示Eureka Server是否将自己作为客户端注册到Eureka Server中。false表示Eureka Server不会将自己注册到Eureka Server中。

  • eureka: client: fetchRegistry: false:表示Eureka Server是否获取Eureka Server注册表上的注册信息。这里设置为false,表示Eureka Server不会获取Eureka Server注册表上的注册信息。
    在Eureka配置中默认情况,这个值为true,表示Eureka客户端会从Eureka Server获取注册信息。如果你设置这个值为false,那么Eureka客户端将不会从Eureka Server获取注册信息。比如当你的Eureka Server是单点的,不需要同步其他节点的数据时。

  • eureka: client: serviceUrl: defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/:Eureka Server的地址。

  • eureka: instance: hostname: localhost:Eureka Server实例的主机名。

这个配置文件定义了Eureka Server的基本配置,包括端口号、是否将自己注册到Eureka Server中、是否获取Eureka Server注册表上的注册信息、Eureka Server的地址以及Eureka Server实例的主机名。

3.2 创建Eureka Client关键步骤:

  1. 添加依赖:在你的pom.xml文件中添加Eureka Client的依赖。
<dependencies>
  <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
  </dependency>
</dependencies>
  1. 配置Eureka Client:在你的application.ymlapplication.properties文件中配置Eureka Client。目的:将Eureka 客户端注册到运行在http://localhost:8761/eureka/的Eureka服务上,并且使用localhost作为主机名。也可以使用ip地址作为主机名【eureka.instance.prefer-ip-address=true】
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/   
  instance:
    hostname: localhost
  1. 启动Eureka Client:在你的Spring Boot应用程序的主类中添加@EnableEurekaClient注解,并运行该类以启动Eureka Client。
@SpringBootApplication
@EnableEurekaClient
public class EurekaclientApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaclientApplication.class, args);
    }
}

完整代码点这里

4.概念过程理解

  • 4.1服务注册的过程:
    1.启动服务提供者:微服务启动后,会周期性的向Eureka Server发送心跳(默认周期为30秒)以续约自己的信息。
    2.服务注册:服务提供者将相关服务信息主动注册到注册中心。【注册中心本质上是为了解耦服务提供者在和服务消费者】
    3.获取服务注册信息:服务消费者可以主动拉取可用的服务提供者清单(Pull模式),或者服务消费者订阅服务(当服务提供者有变化时,注册中心也会主动推送更新后的服务清单给消费者(Push模式))
    4.服务调用:服务消费者直接调用服务提供者。
    5.健康监控:注册中心需要完成服务提供者的健康监控,当发现服务提供者失效时需要及时剔除。
    拓展:Pull模式和Push模式

  • 4.2 服务发现过程:
    1.服务发现:微服务通过Eureka Client向Eureka Server请求其他服务的信息。
    2.获取服务信息:Eureka Server返回请求的服务信息,包括服务的网络地址和端口等
    3.服务调用:微服务根据获取的服务信息,通过HTTP或其他协议调用目标服务。
    在Spring Cloud中,可以使用RestTemplate或Feign来实现服务发现和调用。

  • 4.3 服务下线过程:
    1.服务下线请求:当一个服务实例需要停止时,它会向Eureka Server发送一个取消请求。
    2.服务注销:Eureka Server在接收到这个请求后,会将该服务实例从其注册表中删除。
    3.服务同步:Eureka Server会将这个服务实例的注销信息同步到集群中的其他Eureka Server

  • 4.4 服务同步是分布式系统中一个重要过程,用于保持各个节点上的服务信息一致。
    服务同步过程:

    1.服务注册:当一个服务实例启动并注册到服务注册中心时,它会将自己的服务信息(服务名称,网络地址等)发送给服务注册中心。
    2.服务信息更新:服务注册中心在接收到新的服务信息后,会更新自己的服务注册表。
    3.服务信息同步:服务注册中心会将新的服务信息复制(或推送)到集群中的其他节点。这样,集群中的所有节点都能拥有最新的服务信息。
    4.服务信息确认:其他节点在接收到新的服务信息后,会向服务注册中心发送确认信息。这样,服务信息中心就知道新的服务信息已经成功同步到所有节点。

  • 4.5 服务续约过程:
    1.微服务启动:微服务启动后,会向Eureka注册自己的服务信息。
    2.发送心跳:微服务会周期性的向Eureka Server发送心跳(默认周期30秒)以续约自己的信息。心跳是一种信号,用来告诉Eureka Server 微服务仍然在线。
    3.心跳检测:Eureka Server会定期检测每个服务实例的心跳。如果在一定时间内(默认90秒)没有接收到某个服务实例的心跳,Eureka Server将会注销该服务实例。

  • 4.6 自我保护机制:
    Eureka的自我保护机制是一种用于处理网络分区场景的保护机制。当Eureka Server在运行期间统计到心跳失败比例在15分钟之内低于85%时【发生这种情景暂时分为两种情况:1.可能发生在网络状况不佳的情况下,实例仍在运行,但是暂时无法到达 2.客户端突然关闭】,它会将这些实例保护起来,让这些实例不会过期。
    Eureka Server会在启动时从其他服务器节点同步注册表,然后将这些信息注册到本地的注册表中。在这个过程中,它会返回一个同步实例的数量,然后根据这个数量计算出期望的心跳数。每当有一个新的服务实例注册时,期望的心跳数就会增加2,而当一个服务实例下线时,期望的心跳数就会减少2。
    Eureka Server还会维护两个心跳计数器,一个用于统计当前分钟收到的心跳数量,另一个用于存储上一分钟收到的心跳数。如果上一分钟收到的心跳数小于期望的心跳数85%,那么就是触发自我保护机制。此时,服务实例不会被过期。
    总结:Eureka的自我保护机制是一种防止由于网络问题导致的服务实例错误过期的机制。

  • 4.7 负载均衡:当服务消费方需要调用某个服务时,Eureka客户端会在获取到的服务列表中进行负载均衡,选择一个合适的服务实例进行调用。
    ----- 负载均衡算法主要有以下几种

  • 4.7.1 随机算法:最简单的算法,即从一组服务器中随机选择一个进行服务请求。适用于每台服务器的性能差不多的情况。

  • 4.7.2 权重随机算法:每个服务器都有一个权重值,权重值越大,被选中的概率就越大。适用于服务器性能不均匀的情况。

  • 4.7.3 轮询算法:按照顺序依次从服务器列表中选取服务器,如果列表到达末尾,则又从头开始选取。

  • 4.7.4 权重轮询算法: 是轮询算法和权重随机算法的结合,不仅考虑了服务器的顺序,也考虑了服务器的权重。

  • 4.7.5 最少连接算法: 会优先选择当前连接数最少的服务器,以保证负载的均衡。

为什么要搭建Eureka注册中心集群?
为了提高系统的高可用性和稳定性
1.如果所有服务都注册到一个Eureka Server上,一旦这个Server宕机,所有的服务调用都会出现问题。通过搭建Eureka注册中心集群,即使某个Eureka Server节点宕机,其他节点仍然可以提供服务。【服务的高可用性】
2.Eureka Server集群中的各个节点会彼此同步数据,确保所有节点数据的一致性。【数据的一致性】
3.通过Eureka集群,可以将服务的注册和发现请求分散到多个节点上,从而减轻单个节点的压力。【负载均衡】
4.如果一个Eureka Server节点发生故障,其他节点可以接管其工作,保证系统的正常运行。【容错性】
5.即使所有的Eureka Server节点都宕机,Eureka Client依然能够获取到想要调用服务的地址(但地址可能不准确),因为Eureka Client会自动拉取、更新以及缓存Eureka Server中的信息。【服务发现的可靠性】

二、ZooKeeper
1.概念:
ZooKeeper是一个分布式协调服务,由Apache进行维护。可以视为一个高可用的文件系统,用于发布/订阅、负载均衡、命令服务,分布式协调/通知、集群管理、Master选举、分布式锁和分布式队列等功能。
2.作为注册中心,被广泛应用于各种分布式系统和大数据领域。具体的应用场景

  • 1.分布式配置中心:发布者可以将数据发布到ZooKeeper的一个或一系列的节点上,供订阅者进行数据订阅,从而实现动态获取数据的目的。
  • 2.服务发现:在微服务架构中,服务实例有可能动态的上线、下线或者迁移到其他服务器,因此需要一种机制能够实时的发现服务实例的存在。ZooKeeper的临时节点和Watcher机制可以很好的支持这种服务发现的需求。
  • 3.负载均衡:ZooKeeper可以存储所有提供服务的主机的状态数据,根据这些数据,客户端可以做出智能的负载均衡决策。
  • 4.分布式锁:ZooKeeper可以用来实现分布式锁,从而控制分布式环境下的并发访问。
  • 5.集群管理:ZooKeeper可以用来监控集群的状态,当某个节点出现故障时,可以快速、准确的检测到。
    在开源项目中,例如HBase,Spark,Flink,Storm,Kafka,Dubbo等,都使用ZooKeeper作为其注册中心。

3.作为注册中心,ZooKeeper的主要功能包括

  • 1.服务注册:服务提供者启动时,将自己的服务地址等信息注册到ZooKeeper对应的节点上。
  • 2.服务发现:服务消费者在需要调用服务时,从ZooKeeper获取服务提供者的地址信息,然后直接调用服务提供者。
  • 3.服务列表维护:ZooKeeper会持续监听注册在其上的服务,一旦有服务下线,ZooKeeper会将其从服务列表中移除,同时通知到相关的服务消费者。
  • 4.负载均衡:ZooKeeper可以存储所有提供服务的主机的状态数据,根据这些数据,客户端可以做出智能的负载均衡决策。

4.步骤:

  • 1.安装并启动ZooKeeper服务
  • 2.服务注册和发现:查看代码点这里
    服务提供者在启动时,将自己的服务地址、端口号等信息注册到ZooKeeper的指定节点上。
    服务消费者在需要调用服务时,首先从ZooKeeper获取服务提供者的地址信息,然后再进行服务调用。
  • 3.监听服务变化:服务消费者可以在ZooKeeper上对感兴趣的服务节点添加监听,一旦服务节点的信息发生变化(如服务提供者下线或新的服务提供者注册),ZooKeeper会通知服务消费者。
    在SpringCloud中,可以使用@EventListener注解来监听ZooKeeper服务的变化。ZooKeeper的getData(), getChildren(), 和 exists()方法都可以用来设置监听器。具体设置步骤点这里
  • 4.服务下线:服务提供者在关闭时,需要将自己在ZooKeeper上的注册信息删除,表明自己已经下线。
    5.使用场景
    做配置中心(实现数据发布/订阅):全局的配置信息、服务式服务框架的服务地址列表。
    应用在启动的时候会主动获取一次配置,在节点上注册一个Watcher,每次配置有变动的时候,都会实时通知订阅的客户端获取最新配置信息。
    做负载均衡:分布式环境中,为了保证高可用性,同一个服务的多个实例可能会部署在不同的服务器上。服务消费者(客户端应用功能或另一个服务)需要调用该服务的时候,可以从这些服务器中选择一个来处理请求。
    用来命名服务(提供名称的服务):提供类JNDI功能,可以吧系统中各个服务的名称、地址以及目录信息放在ZooKeeper,需要的时候偶去ZooKeeper中读取。
    分布式协调/通知:ZooKeeper中特有watcher注册与异步通知机制,能够很好的实现分布式环境下不同系统之间的通知与协调,实现对数据变更的实时处理。
    分布式锁:ZooKeeper提供了分布式锁机制,可以帮助分布式应用程序实现并发控制和同步。具体实现步骤点这里
    分布式队列:实现任务调度和消息传递。

后续更新

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【深度学习】DDoS-Detection-Challenge aitrans2024 入侵检测,基于机器学习(深度学习)判断网络入侵

当了次教练&#xff0c;做了个比赛的Stage1&#xff0c;https://github.com/AItransCompetition/DDoS-Detection-Challenge&#xff0c;得了100分。 一些记录&#xff1a; 1、提交的flowid不能重复&#xff0c;提交的是非入侵的数量和数据flowid,看check.cpp可知。 2、Stage…

redis底层数据结构之ziplist

目录 一、概述二、ziplist结构三、Entry结构四、为什么ZipList特别省内存五、ziplist的缺点 redis底层数据结构已完结&#x1f44f;&#x1f44f;&#x1f44f;&#xff1a; ☑️redis底层数据结构之SDS☑️redis底层数据结构之ziplist☑️redis底层数据结构之quicklist☑️red…

Docker的资源控制管理——Cgroups

目录 引言&#xff1a; 一、CPU资源控制 1、简介 2、cgroup的四大功能&#xff1a; ①资源限制&#xff1a; ②优先级分配&#xff1a; ③资源统计&#xff1a; ④任务控制&#xff1a; 3、设置cpu使用率上限 4、查看CPU默认配置&#xff1a; 5、CPU压力测试 6、设…

H264编码标准中游程编码应用介绍

H264编码标准 H.264编码标准&#xff0c;也被称作MPEG-4 AVC&#xff08;Advanced Video Coding&#xff09;&#xff0c;是一种被广泛使用的数字视频压缩标准。它由国际电信联盟&#xff08;ITU-T&#xff09;和国际标准化组织&#xff08;ISO&#xff09;共同开发&#xff0…

C++核心编程——4.5 运算符重载

4.5.0 运算符重载概念 对已有的运算符重新进行定义&#xff0c;赋予其另一种功能&#xff0c;以适应不同的数据类型 4.5.1 加号运算符重载 作用&#xff1a;实现两个自定义数据类型相加的运算 class Person { public:Person() {};Person(int a, int b){this->m_A a;this…

Bayes判别:统计学中的经典分类方法

在统计和机器学习领域&#xff0c;Bayes判别是一个基于概率理论的强大工具&#xff0c;用于解决分类问题。它基于Bayes定理&#xff0c;通过计算和比较后验概率来进行决策。这种方法在处理不确定性和不完整数据时表现尤为出色&#xff0c;因此在医学诊断、邮件过滤、语音识别等…

《十》Qt各种对话框之QFontDialog

QFontDialog 在介绍 QFontDialog 对话框之前&#xff0c;我们先简单介绍一下 QFont 字体类。QFont 主要用于控制文本显示的字体&#xff0c;字体主要有四大属性&#xff1a;①字体家族 family 决定字体外观家族&#xff0c;比如宋体、楷体等&#xff1b; ②字号 pointSize &am…

css文字和span在一行对不齐

1.需求背景 父盒子中有两个span&#xff0c;但是span中的文字对不齐。如下图&#xff0c;明显右边的文字偏高 处理后的效果&#xff08;已经对齐&#xff0c;图中标记的是基本的div结构&#xff09;&#xff1a; 2.该问题出现的原因&#xff1a; span1设置的高度比span2内…

thsi指针用法总结

1 c类对象中的变量和函数是分开存储的 2 所以对象共用一份成员函数&#xff0c;类的大小是指非静态的成员变量&#xff1b; this 完成链式操作 const 修饰成员函数

【Java 解析全国详细地址】Java 利用正则表达式完美解析全国省市区地址

这里写自定义目录标题 Java使用正则解析省市区/县 具体地址问题场景上demo运行结果 Java使用正则解析省市区/县 具体地址 问题场景 OCR识别营业执照 获取详细地址并拆分 上demo import java.util.HashMap; import java.util.Map; import java.util.regex.Matcher; import j…

使用API有效率地管理Dynadot域名,自查账户信息

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

日本岛津电子天平UW UX 系列series 精密电子天平Shimadzu使用说明

日本岛津电子天平UW UX 系列series 精密电子天平Shimadzu使用说明

2024春季春日主题活动策划方案

2024解冻派对“春日浪漫”主题活动策划方案-32P 方案页码&#xff1a;32页 文件格式&#xff1a;pptx 方案简介&#xff1a; 春来一季&#xff0c;新生欢喜 花香丨微风丨阳光 活动唤起【春日浪漫记忆】&#xff01; 年轻人不一样的派对活动 可以与朋友/小朋友/家人互动…

MT3030 天梯赛

跟MT3029战神小码哥类似&#xff0c;都是贪心堆。注意开long long 这里的堆顶为战斗力最小的&#xff0c;便于贪心的反悔操作。先按容忍度从大到小排序&#xff08;q中总容忍度取决于最小的容忍度&#xff09;&#xff0c;再向q中存数&#xff0c;存到不能容忍之后再把堆顶踢出…

最简单也最复杂的德语动词,柯桥德语培训

德语人一定遇到过这个难题&#xff1a;ie组合到底发什么音&#xff1f; 说起haben&#xff0c;大家可能第一感觉是“这么简单的动词也要讲&#xff1f;不就是‘拥有’的意思吗&#xff1f;” 没错&#xff0c;haben的基本含义是“拥有&#xff0c;包含”&#xff0c;但是在某些…

Vue3后台管理系统推荐

目录 项目概述 &#x1f35f; 项目展示 功能特点 &#x1f957; 结语 &#x1f4a8; 项目概述 &#x1f35f; 基于Vue 3框架与Element-Plus UI组件库技术精心构建的后端管理模板。该模板系统已成功实现一个基础的权限管理模块&#xff0c;宗旨在于为追求高效二次开发的开发…

制作一个RISC-V的操作系统十四-任务同步和锁

文章目录 并发与同步临界区和锁锁死锁解决死锁自旋锁&#xff08;spin lock&#xff09;原子性问题原子操作实现amoswap.w.aq例子 另一种方法自旋锁的注意事项代码其他同步技术 并发与同步 控制流&#xff1a;可理解为任务或进程 中断也可以理解为一个切换到另一个任务&#…

【Linux网络】DHCP原理与配置

目录 一、DHCP工作原理 1.了解DHCP服务 2.使用DHCP的好处 3.DHCP的分配方式 二、DHCP的租约过程 三、DHCP场景应用实验 一、DHCP工作原理 1.了解DHCP服务 DHCP&#xff08;Dynamic Host Configuration Protocol&#xff0c;动态主机配置协议&#xff09; 由Internet工作…

<计算机网络自顶向下> 无连接传输UDP

UDP&#xff1a;User Datagram Protocol “尽力而为”的服务 报文可能丢掉或者乱序好处&#xff1a; 效率高&#xff08;不建立连接无拥塞控制和流量控制【应用->传输的速率主机->网络的速率】&#xff09;报文段的头部很小&#xff08;开销小&#xff09;UDP被用于 流媒…

数据结构系列-堆排序当中的T-TOK问题

&#x1f308;个人主页&#xff1a;羽晨同学 &#x1f4ab;个人格言:“成为自己未来的主人~” 之前我们讲到了堆排序的实现逻辑&#xff0c;那么接下来我们重点关注的就是其中的T-TOK问题 T-TOK说简单点&#xff0c;就是说&#xff0c;假如有10000个数据&#xff08;随机的…
最新文章