SpringCloud-Netflix学习笔记05——Eureka模拟实现简单集群

news2025/1/16 15:50:57

前言

  对于Eureka注册中心来说,如果只有一个注册中心的话,如果注册中心崩了,那么里面的服务全部用不了,系统就会崩溃。为了避免这个问题,我们可以搭建一个注册中心的集群,几个注册中心互相关联,如果一个注册中心崩了,另外的几个注册中心还能用,服务还能用,系统就不会崩溃。

准备

  我们用一台电脑模拟集群,为了直观上看起来更像集群,所以我们要做一下域名映射。

  找到 hosts 文件,打开文件,添加几个语句。

在这里插入图片描述

  我们用三个Eureka注册中心搭建集群,所以做三个域名映射。无论访问 eureka7001.com 还是另外两个,都会跳转到 127.0.0.1locahost 。保存退出。

在这里插入图片描述

集群搭建

1、搭建三个注册中心

  我们先用IDEA搭建三个Eureka注册中心,端口分别为7001、7002、7003。具体搭建方法,看我的另一篇博客。此时这三个注册中心是没有任何关系的,如图示:

在这里插入图片描述

  我们需要做的就是,把这三个注册中心关联在一起,组成一个集群。即7001要关联7002和7003,7002要关联7001和7003,7003要关联7001和7002,如图示:

在这里插入图片描述

2、修改配置文件

  要实现上面的操作,我们只需要修改配置文件即可。

7001配置文件修改

  将 hostname 修改为我们自己的域名,即 eureka7001.com

  关联7002和7003,将 defaultZone 修改为 http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

server:
  port: 7001

# Eureka注册中心的配置 ,搭建集群情况下,和7002以及7003搭建集群,关联7002和7003
eureka:
  server:
    enable-self-preservation: true  # 开启自我保护模式
  instance:
    hostname: eureka7001.com  # Eureka服务端的实例名称,即注册中心的名称,或者主机名
  client:
    register-with-eureka: false  # 表示是否将自己往Eureka注册中心注册,因为自己就是注册中心,所以false
    fetch-registry: false  # 如果fetch-registry为false,则表示自己是注册中心,否则为客户端
    service-url:  # 监控页面,可以在这个url中监控注册中心的服务
      defaultZone: http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

  7002注册中心和7003注册中心也是类似的,我直接贴出代码。

7002配置文件修改
server:
  port: 7002

# 单机情况下看7001的yml文件

# Eureka注册中心的配置,搭建集群情况下,和7001以及7003搭建集群,关联7001和7003
eureka:
  server:
    enable-self-preservation: true  # 开启自我保护模式
  instance:
    hostname: eureka7002.com  # Eureka服务端的实例名称,即注册中心的名称
  client:
    register-with-eureka: false  # 表示是否将自己往Eureka注册中心注册,因为自己就是注册中心,所以false
    fetch-registry: false  # 如果fetch-registry为false,则表示自己是注册中心,否则为客户端
    service-url:  # 监控页面,可以在这个url中监控注册中心的服务
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7003.com:7003/eureka/

7003配置文件修改
server:
  port: 7003

# 单机情况下看7001的yml文件

# Eureka注册中心的配置,搭建集群情况下,和7001以及7002搭建集群,关联7001和7002
eureka:
  server:
    enable-self-preservation: true  # 开启自我保护模式
  instance:
    hostname: eureka7003.com  # Eureka服务端的实例名称,即注册中心的名称
  client:
    register-with-eureka: false  # 表示是否将自己往Eureka注册中心注册,因为自己就是注册中心,所以false
    fetch-registry: false  # 如果fetch-registry为false,则表示自己是注册中心,否则为客户端
    service-url:  # 监控页面,可以在这个url中监控注册中心的服务
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/

3、启动测试

  分别启动三个注册中心,访问7001管理页面,即 http://eureka7001.com:7001/ ,我们可以发现,7001已经关联了7002和7003,如图:

在这里插入图片描述
  类似的访问7002和7003的管理页面,也和这个类似。

在这里插入图片描述

在这里插入图片描述

服务提供者修改

  我们已经从单一注册中心,变成了一个由三个注册中心搭建的集群,那么服务提供者应该怎么把服务注册到注册中心呢?

  其实很简单,修改注册中心地址即可,打开服务提供者的配置文件,将 defaultZone 修改为 http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/ ,即将服务同时注册到三个注册中心。启动服务进行测试,如图:

在这里插入图片描述

  服务已经注册到了集群中,7002和7003也类似。

总结

  通过Eureka注册中心搭建集群,只需要修改配置文件即可,十分方便。如果一个节点(注册中心)突然崩了,那么另外两个节点还正常运行,能正常提供服务,不会影响到系统的运行。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

程序员别死背面试八股文了,这种面试题才是未来主流。。。

目录: 面试官为啥要出这样一个开放式问题生产消费模型及核心数据结构支撑TB级数据写入的分布式架构数据宕机场景下的高可用架构支持数据不丢失的ack机制最后的总结 1、面试官为啥要出这样一个开放式问题 这篇文章简单给大家来聊一个互联网大厂的Java面试题&#x…

【Git 从入门到精通】一文摸透Git中的分支操作

文章目录一、什么是分支?二、分支中的常用命令三、上手分支1.查看分支2.创建分支3.修改分支4.切换分支5.合并分支6.解决冲突四、分支操作原理分析一、什么是分支? 在版本控制过程中,同时推进多个任务,为每个任务,我们…

肠道核心菌——戴阿利斯特杆菌属 (Dialister)

谷禾健康 戴阿利斯特杆菌属 (Dialister) ✦ Dialister(戴阿利斯特杆菌属)是小的、厌氧或微需氧的革兰氏阴性球状或杆状菌,因次也被翻译成小杆菌属。 Dialister菌是人体肠道菌群中的一种常见菌种。该菌属物种被发现出现…

基于 Hutool 的抽奖实现与原理

前言 先大概描述下 hutool 工具是如何根据权重进行抽取,后面再结合源码进行讲解。 假设有如下奖品以及对应的权重: 奖品名称权重奖品数量谢谢参与0.76010积分0.4550IPhone 140.055Mac Book Air0.011 需要注意 谢谢参与 也算是一种奖品,因为…

SpringCloud-Netflix学习笔记04——Eureka注册中心搭建

前言 Eureka注册中心相当于Zookeeper注册中心,思想是类似的,只不过Zookeeper需要在本机上下载一个服务客户端,直接启动客户端即可,而Eureka注册中心需要我们自己动手搭建,不过也不难。 搭建步骤 1、新建一个Maven项目…

PySpark数据计算中常用的成员方法(算子)

目录 一.回顾 二.数据计算 map算子 演示 flatMap算子 演示 reduceByKey算子 演示 练习案例1 需求 解决步骤 完整代码 filter算子 演示 distinct算子 演示 sortBy算子 演示 练习案例2 解决步骤 完整代码 三.总结 一.回顾 1.RDD对象是什么?为什么要使用它? RDD对象称…

SegFormer学习笔记(1)安装

一、源码:https://github.com/sithu31296/semantic-segmentation我并没使用SegFormer的官方源码,那个mmcv特磨人了,各种奇葩配置错误。二、环境配置新建conda环境conda create -n segformer3715 python3.7.15 选用python3.7.15(纯粹的3.7.0版…

计算机原理四_内存管理

目录儿三、内存管理3.1 内存管理基础3.1.1存储器的多层结构3.1.2 进程运行基本原理进程的装入3.1.3 内存扩充3.1.4 内存的分配3.1.4.1连续分配3.1.4.2非连续分配3.1.4.2.1基本分页存储管理3.1.4.2.2基本分段存储管理3.1.4.2.3 段页式管理3.2 虚拟内存管理3.2.1 虚拟内存的概念3…

【BP靶场portswigger-客户端11】跨站点脚本XSS-10个实验(下)

前言: 介绍: 博主:网络安全领域狂热爱好者(承诺在CSDN永久无偿分享文章)。 殊荣:CSDN网络安全领域优质创作者,2022年双十一业务安全保卫战-某厂第一名,某厂特邀数字业务安全研究员&…

【Go基础】函数和面向接口编程

文章目录一、函数1. 函数的基本形式2. 递归函数3. 匿名函数4. 闭包5. 延迟调用defer6. 异常处理二、面向接口编程1. 接口的基本概念2. 接口的使用3. 接口的赋值4. 接口嵌入5. 空接口6. 类型断言7. 面向接口编程一、函数 1. 函数的基本形式 // 函数定义:a,b是形参 …

【测试】自动化测试

努力经营当下,直至未来明朗! 文章目录一、自动化概述二、自动化测试的分类三、自动化测试工具:selenium四、一个简单的自动化用例五、Selenium常用方法1. 查找页面元素:2.元素的定位(By类)小结普通小孩也要…

Java中this的用法

一、this关键字 1.this的类型:哪个对象调用就是哪个对象的引用类型 二、用法总结 1.this.data; //访问属性 2.this.func(); //访问方法 3.this(); //调用本类中其他构造方法 三、解释用法 1.this.data 这种是在成员方法中使用 让我们来看看不加this会出现什…

ArcGIS基础实验操作100例--实验95平滑处理栅格数据

本实验专栏参考自汤国安教授《地理信息系统基础实验操作100例》一书 实验平台:ArcGIS 10.6 实验数据:请访问实验1(传送门) 空间分析篇--实验95 平滑处理栅格数据 目录 一、实验背景 二、实验数据 三、实验步骤 (1&…

ST算法解决BMQ问题详解(图文并茂,保证看懂)

一.RMQ问题的概念RMQ(Range Minimum/Maximum Query)问题,简单说就是求区间最值问题,是求区间最大值或最小值,即范围最值问题,若是简单的单次询问或者是区间长度很短的询问,可以用暴力的方法来实…

【web安全】——文件上传漏洞

作者名:白昼安全主页面链接: 主页传送门创作初心: 舞台再大,你不上台,永远是观众,没人会关心你努不努力,摔的痛不痛,他们只会看你最后站在什么位置,然后羡慕或鄙夷座右铭…

【寒假第2天】LeetCode刷题

🌈一、选择题 👿第1题: 下面给出的四种排序法中( )排序法是不稳定性排序法A.插入排序 B.冒泡排序 C.归并排序 D.堆,希尔排序,快速排序 答案:D 为啥堆排序是不稳定的&am…

SCA 工具:开源安全威胁一手掌控

1、什么是 SCA SCA(Software Composition Analysis)软件成分分析,通俗的理解就是通过分析软件包含的一些信息和特征来实现对该软件的识别、管理、追踪的技术。我们知道在当今软件开发中,引入开源软件(注 1)到你的项目中&#xff…

线性DP-----(从某点走到某点求最值问题)

线性DP 线性dp问题是dp问题中比较简单的问题,通常一个状态转移方程就可以搞定,线性dp通常求最大值,最小值问题,下面介绍线性dp中从某点走到某点最值问题。 第一类问题(走一遍) 该类问题只走一遍,动态规划中用到的数组f(i,j)含义就是到达(i,j)点得到的最优解 例题1—数字三角形 …

分享88个JavaScript源码,总有一款适合您

JavaScript源码 分享88个JavaScript源码,总有一款适合您 JavaScript源码下载链接:https://pan.baidu.com/s/1guiYWOPKdP1zNW7T8P0caQ?pwd6666 提取码:6666 采集代码下载链接:采集代码.zip - 蓝奏云 下面是文件的名字&#xf…

jinja2 循环计数内置变量loop

变量内容loop.index循环迭代计数(从1开始)loop.index0循环迭代计数(从0开始)loop.revindex循环迭代倒序计数(从len开始,到1结束)loop.revindex0循环迭代倒序计数(从len-1…