第四章:服务注册中心 Eureka

4-1. Eureka 注册中心高可用集群概述在微服务架构的这种分布式系统中,我们要充分考虑各个微服务组件的高可用性

问题,不能有单点故障,由于注册中心 eureka 本身也是一个服务,如果它只有一个节点,那么它有可能发生故障,这样我们就不能注册与查询服务了,所以我

们需要一个高可用的服务注册中心,这就需要通过注册中心集群来解决。eureka 服务注册中心它本身也是一个服务,它也可以看做是一个提供者,又可

以看做是一个消费者,我们之前通过配置:eureka.client.register-with-eureka=false  让注册中心不注册自己,但是我们可以向其他注册中心注册自己;

Eureka  Server  的高可用实际上就是将自己作为服务向其他服务注册中心注册自己,这样就会形成一组互相注册的服务注册中心,进而实现服务清单的互相同

步,往注册中心 A 上注册的服务,可以被复制同步到注册中心 B 上,所以从任何一台注册中心上都能查询到已经注册的服务,从而达到高可用的效果。

4-2. Eureka 注册中心高可用集群搭建

我们知道,Eureka 注册中心高可用集群就是各个注册中心相互注册,所以:(可以在新建一个项目作为注册中心,但是这里为了方便,采用多环境配置方法启动两个Eureka注册中心)

1.在 8761 的配置文件中,让它的 service-url 指向 8762,在 8762 的配置文件中让它的 service-url 指向 8761

2.由于 8761 和 8762 互相指向对方,实际上我们构建了一个双节点的服务注册中心集群

eureka.client.service-url.defaultZone=http://eureka8762:8762/eureka/
eureka.client.service-url.defaultZone=http://eureka8761:8761/eureka/

因为注册地址eureka8761 不是域名,浏览器无法访问到,所以我们配置host,让eureka8761指向本地

修改方法:

找到本地 hosts 文件:C:\Windows\System32\drivers\etc\hosts

127.0.0.1  eureka8761

127.0.0.1  eureka8762

因为需要启动两个注册中心,所以我们吧main方法类拷贝两份,

运行时,制定配置文件运行,8761main类就用8761配置文件在运行配置项目 Program Arguments  中配置:

--spring.profiles.active=eureka8761

--spring.profiles.active=eureka8762

同样的方式配置8762启动方式,这里截图省略。

分别启动两个注册中心,访问两个注册中心页面,观察注册中心页面是否正常;

4-3. Eureka 注册中心高可用集群测试

在要进行注册的服务中配置:(即项目1,服务提供者)

eureka.client.service-url.defaultZone=http://eureka8761:8761/eureka/,http://eureka8762:8762/eureka/

笔者在这里遇到了一个坑,服务提供者启动的时候总是启动报错,注册服务失败,原因是host文件没有生效,eureka8761并没有指向localhost,(之前都是手动配置host文件,这一次用notepad++打开配置的,没想到表面配置成功,其实并没有成功,真是一个坑啊)

启动服务提供者服务,然后观察注册中心页面,可以看到服务会在两个注册中心上都注册成功;

配置消费者,然后启动

启动成功之后,发现两个eureka都已经注册了服务

4-4. Eureka 服务注册中心自我保护机制

自我保护机制是 Eureka 注册中心的重要特性,当 Eureka 注册中心进入自我保护模式时,在 Eureka Server 首页会输出如下警告信息:

EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY'RE NOT.

RENEWALS ARE LESSER THAN THRESHOLD AND HENCE THE INSTANCES ARE NOT BEING EXPIRED

JUST TO BE SAFE.

emergency! eureka may be incorrectly claiming instances are up when they're not. renewals are

lesser than threshold and hence the instances are not being expired just to be safe.

在没有 Eureka 自我保护的情况下,如果 Eureka Server 在一定时间内没有接收到某个微服务实例的心跳,Eureka Server 将会注销该实例,但是当发生网络分

区故障时,那么微服务与 Eureka Server 之间将无法正常通信,以上行为可能变得非常危险了——因为微服务本身其实是正常的,此时不应该注销这个微服务,

如果没有自我保护机制,那么 Eureka Server 就会将此服务注销掉。Eureka 通过“自我保护模式”来解决这个问题——当 Eureka Server 节点在短

时间内丢失过多客户端时(可能发生了网络分区故障),那么就会把这个微服务节点进行保护。一旦进入自我保护模式,Eureka Server 就会保护服务注册表中

的信息,不删除服务注册表中的数据(也就是不会注销任何微服务)。当网络故障恢复后,该 Eureka Server 节点会再自动退出自我保护模式。

所以,自我保护模式是一种应对网络异常的安全保护措施,它的架构哲学是宁可同时保留所有微服务(健康的微服务和不健康的微服务都会保留),也不盲目注

销任何健康的微服务,使用自我保护模式,可以让 Eureka 集群更加的健壮、稳定。当然也可以使用配置项:eureka.server.enable-self-preservation=  false

禁用自我保护模式。但是 Eureka  Server  自我保护模式也会给我们带来一些困扰,如果在保护期内某个服务提供者刚好非正常下线了,此时服务消费者就会拿到一个无效的服务实

例,此时会调用失败,对于这个问题需要服务消费者端具有一些容错机制,如重试,断路器等。

Eureka 的自我保护模式是有意义的,该模式被激活后,它不会从注册列表中剔除因长时间没收到心跳导致注册过期的服务,而是等待修复,直到心跳恢复正常

之后,它自动退出自我保护模式。这种模式旨在避免因网络分区故障导致服务不可用的问题。

例如,两个微服务客户端实例 A 和 B 之间有调用的关系,A 是消费者,B 是提供者,但是由于网络故障,B 未能及时向 Eureka 发送心跳续约,这时候 Eureka

不能简单的将 B 从注册表中剔除,因为如果剔除了,A 就无法从 Eureka  服务器中获取 B 注册的服务,但是这时候 B 服务是可用的;

所以,Eureka 的自我保护模式最好还是开启它。

关于自我保护常用几个配置如下:

服务器端配置:

#测试时关闭自我保护机制,保证不可用服务及时踢出

eureka.server.enable-self-preservation=false

客户端配置:

#每间隔 2s,向服务端发送一次心跳,证明自己依然"存活"   默认30秒
eureka.instance.lease-renewal-interval-in-seconds=2
#告诉服务端,如果我 10s 之内没有给你发心跳,就代表我故障了,将我踢出掉 默认90秒
eureka.instance.lease-expiration-duration-in-seconds=10

启动eureka服务端,可以看得到自我保护机制已经关闭,

在启动服务提供者,刷新eureka服务端,可以看到服务已经注册成功,

关闭服务提供者,模拟异常,数十秒后发现eureka服务端已经将服务提供者踢掉。通过日志可以发现,已经将其剔除,服务已经没了。(我设置值10秒不发心跳就踢除,实际测试中要大于10秒 需要等一小段时间)

SpringCloud(四):服务注册中心Eureka Eureka高可用集群搭建 Eureka自我保护机制的更多相关文章

  1. SpringCloud全家桶学习之服务注册与发现及Eureka高可用集群搭建(二)

    一.Eureka服务注册与发现 (1)Eureka是什么? Eureka是NetFlix的一个子模块,也是核心模块之一.Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故 ...

  2. spring cloud 服务注册中心eureka高可用集群搭建

    spring cloud 服务注册中心eureka高可用集群搭建 一,准备工作 eureka可以类比zookeeper,本文用三台机器搭建集群,也就是说要启动三个eureka注册中心 1 本文三台eu ...

  3. Redis安装、主从配置及两种高可用集群搭建

    Redis安装.主从配置及两种高可用集群搭建 一.            准备 Kali Linux虚拟机 三台:192.168.154.129.192.168.154.130.192.168.154 ...

  4. zookeeper+activemq高可用集群搭建

    一.准备工作: 准备三台机器:192.168.35.111192.168.35.112192.168.35.113 二.搭建zookeeper 三台机器上均要搭建zookeeper服务// 下载zoo ...

  5. Hadoop HA高可用集群搭建(Hadoop+Zookeeper+HBase)

    声明:作者原创,转载注明出处. 作者:帅气陈吃苹果 一.服务器环境 主机名 IP 用户名 密码 安装目录 master188 192.168.29.188 hadoop hadoop /home/ha ...

  6. Hadoop 3.1.2(HA)+Zookeeper3.4.13+Hbase1.4.9(HA)+Hive2.3.4+Spark2.4.0(HA)高可用集群搭建

    目录 目录 1.前言 1.1.什么是 Hadoop? 1.1.1.什么是 YARN? 1.2.什么是 Zookeeper? 1.3.什么是 Hbase? 1.4.什么是 Hive 1.5.什么是 Sp ...

  7. MongoDB高可用集群搭建(主从、分片、路由、安全验证)

    目录 一.环境准备 1.部署图 2.模块介绍 3.服务器准备 二.环境变量 1.准备三台集群 2.安装解压 3.配置环境变量 三.集群搭建 1.新建配置目录 2.修改配置文件 3.分发其他节点 4.批 ...

  8. RabbitMQ高级指南:从配置、使用到高可用集群搭建

    本文大纲: 1. RabbitMQ简介 2. RabbitMQ安装与配置 3. C# 如何使用RabbitMQ 4. 几种Exchange模式 5. RPC 远程过程调用 6. RabbitMQ高可用 ...

  9. MHA 高可用集群搭建(二)

    MHA 高可用集群搭建安装scp远程控制http://www.cnblogs.com/kevingrace/p/5662839.html yum install openssh-clients mys ...

随机推荐

  1. B - Power Strings

    Given two strings a and b we define a*b to be their concatenation. For example, if a = "abc&quo ...

  2. PTA 1014 Waiting in Line (30分) 解题思路及满分代码

    题目 Suppose a bank has N windows open for service. There is a yellow line in front of the windows whi ...

  3. Git命令回退代码并同步到远程仓库

    git log 找到要回退的commit版本号并复制 git reset --hard [commitid] 本地库版本回退 git push -f origin [branchName] 同步到远端 ...

  4. 2020ICPC·小米 网络选拔赛第一场

    2020ICPC·小米 网络选拔赛第一场 C-Smart Browser #include <string> #include <iostream> std::string s ...

  5. Excel添加超链接

    using Microsoft.Office.Interop.Excel; Worksheet sheet; public void AddLink(int row, int col, string ...

  6. 【非原创】codeforces - 1067A Array Without Local Maximums【dp】

    学习博客:戳这里 附本人代码: 1 #include <bits/stdc++.h> 2 using namespace std; 3 typedef long long ll; 4 co ...

  7. bochs 调试 com 文件 magicbreak

    参考 https://blog.csdn.net/housansan/article/details/41833581 在网上看到2中解决此问题的方法:1.使用dos下的debug32工具单步跟踪pm ...

  8. zzuli-2266 number

    题目描述 某人刚学习了数位DP,他在某天忽然思考如下问题: 给定n,问有多少数对<x, y>满足: x, y∈[1, n], x < y x, y中出现的[0, 9]的数码种类相同 ...

  9. [转]论基于DSSA的软件架构设计与应用

    [摘要]   去年三月份,我所在的公司启动国网电力用户用电信息采集系统项目,我被任命为项目负责人.国网电力用户用电信息采集系统是国家电网公司坚强智能电网建设的一部分.由于公司之前为南网(主要是广东省) ...

  10. X-Frame-Options & iframe & CORS

    X-Frame-Options & iframe & CORS https://github.com/xgqfrms/FEIQA/issues/23 X-Frame-Options i ...