【Eureka详细讲解】

Eureka介绍和使用

  • 1. Eureka 介绍
  • 2. Eureka 的主要特点
  • 3. 使用
    • 3.1 设置 Eureka Server
    • 3.2 设置 Eureka Client
    • 3.3 Eureka Server 高可用配置

1. Eureka 介绍

Eureka 是由 Netflix 开源的一种服务发现解决方案,它是 Netflix OSS 套件中的一个组件,经常用在微服务架构中。核心作用是服务注册与发现。

当微服务启动时,会把它的网络地址(如 IP 和端口)注册到 Eureka 服务器上,这台服务器被称作 Eureka Server(服务注册中心),其他服务(客户端)启动时,会从 Eureka Server 获取运行中的服务列表,这样服务之间就可以互相调用了。

Eureka 包含两个组件:

  • Eureka Server:服务注册功能的提供方,它提供了界面显示当前注册的服务信息。
  • Eureka Client:服务消费者和提供者,服务启动时,客户端将该服务的信息注册到 Eureka Server 中,服务消费者可以通过 Eureka Server 来发现服务提供者。

2. Eureka 的主要特点

  • AP 系统:根据CAP理论,Eureka是一个典型的AP(可用性、分区容错性)系统,它保证了高可用和分区容错性,但不保证一致性(在某个时间点,可能部分实例信息不同步)。
  • 自我保护模式:为应对网络异常情况,Eureka Server 在运行时可以进入自我保护模式,这时即使没有收到某些微服务的心跳,也不会立即从服务列表中移除该实例。
  • 基于REST的服务间通信:Eureka Server 提供 REST API,方便各种语言编写的服务进行通信。

3. 使用

3.1 设置 Eureka Server

  1. 添加依赖:使用Spring Boot的话,添加spring-cloud-starter-netflix-eureka-server依赖到你的build.gradle或者pom.xml中。
<!-- pom.xml 中的依赖-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  1. 启用 Eureka Server:在 Spring Boot 应用的启动类上添加@EnableEurekaServer注解。
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {public static void main(String[] args) {SpringApplication.run(EurekaServerApplication.class, args);}
}
  1. 配置应用属性:在application.propertiesapplication.yml配置文件中设置 Eureka Server 相关的配置。
# application.yml
server:port: 8761eureka:client:registerWithEureka: falsefetchRegistry: falseserviceUrl:defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

3.2 设置 Eureka Client

  1. 添加依赖:在客户端服务的build.gradlepom.xml中添加spring-cloud-starter-netflix-eureka-client依赖。
<!-- pom.xml 中的依赖 -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
  1. 启用 Eureka Client:在 Spring Boot 应用的启动类上添加@EnableEurekaClient@EnableDiscoveryClient注解。
@SpringBootApplication
@EnableEurekaClient // 或 @EnableDiscoveryClient
public class EurekaClientApplication {public static void main(String[] args) {SpringApplication.run(EurekaClientApplication.class, args);}
}
  1. 配置应用属性:在application.propertiesapplication.yml中配置 Eureka Client 相关的配置,例如注册到 Eureka Server 的地址。
# application.yml
eureka:client:serviceUrl:defaultZone: http://localhost:8761/eureka/

3.3 Eureka Server 高可用配置

在生产环境中,Eureka Server 通常会配置成高可用集群。基本步骤是搭建多个 Eureka Server 实例,它们相互注册为服务(即相互作为客户端)。这样可以保证其中一个实例宕掉时,其他实例可以继续提供服务注册和发现的功能。

以上是搭建和使用 Eureka Server与Client的基本概念和步骤。详细的配置和使用方式可能会根据项目的具体需求有所调整。

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

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

相关文章

8-pytorch-损失函数与反向传播

b站小土堆pytorch教程学习笔记 根据loss更新模型参数 1.计算实际输出与目标之间的差距 2.为我们更新输出提供一定的依据&#xff08;反向传播&#xff09; 1 MSEloss import torch from torch.nn import L1Loss from torch import nninputstorch.tensor([1,2,3],dtypetorch.fl…

(只需三步)免费使用知网的攻略

通过浙江图书馆可以进入知网&#xff0c;并且查看与下载都是免费的。 &#xff08;只需要三步&#xff0c;很简单的。&#xff09; 第一步&#xff1a;注册浙江图书馆账号 打开zfb&#xff0c;搜索“浙江图书馆”小程序&#xff0c;进入个人中心->办理读者证&#xff0c;…

不同尺度下的网络控制方式

《三国演义》和《长安十二时辰》有什么不同&#xff1f; 关羽败走麦城&#xff0c;远在千里之外的刘备收到两个信号&#xff0c;一个需要 “星夜驰援”&#xff0c;紧接着 “二弟休矣”&#xff0c;三国的故事在东亚大陆展开&#xff0c;地理尺度巨大&#xff0c;星夜不星夜其…

PHP语言检测用户输入密码及调用Python脚本

现在有一份计算流体力学N-S方程的Python脚本&#xff0c;想要在用户登录网站后可以可以运行该脚本&#xff0c;然后将脚本运行后绘制的图片显示在用户网页上。 建一个名为N_S.py的python脚本文件&#xff0c;这个脚本在生成图像后会自行关闭&#xff0c;随后将图片保存在指定的…

一篇超级最全的python基础篇

1.数据类型和变量 Python使用缩进来组织代码块,一般使用4个空格的缩进.使用#来注释一行,其他每一行都是一个语句,当语句以冒号:结尾时,缩进的语句视为代码块.Python对大小写敏感. 1.1 整数 Python可以处理任意大小的整数,包括负整数,写法与数学上写法一致,例如:-100.如果用十六…

【文本编辑器,哪款适合你?】讲解

文本编辑器&#xff0c;哪款适合你? 文本编辑器介绍 文本编辑器介绍 电脑使用者在选择文本编辑器时&#xff0c;应该考虑以下几个方面&#xff1a; 需求&#xff1a;你是需要进行基本的文字处理工作&#xff0c;比如写作业或者制作报告&#xff0c;还是需要使用到高级功能&am…

BIO实战、NIO编程与直接内存、零拷贝深入辨析

BIO实战、NIO编程与直接内存、零拷贝深入辨析 长连接、短连接 长连接 socket连接后不管是否使用都会保持连接状态多用于操作频繁&#xff0c;点对点的通讯&#xff0c;避免频繁socket创建造成资源浪费&#xff0c;比如TCP 短连接 socket连接后发送完数据后就断开早期的http服…

简单上手若依框架

简介 若依是一个基于SpringBoot&#xff0c;Shiro&#xff0c;Mybatis的权限后台管理系统官网文档&#xff1a;介绍 | RuoYi源码 前后端不分离 RuoYi: &#x1f389; 基于SpringBoot的权限管理系统 易读易懂、界面简洁美观。 核心技术采用Spring、MyBatis、Shiro没有任何其它重…

InfluxDB的常用数据操作

1.插入语句 # INSERT语句用于向数据库中插入数据点&#xff08;数据行&#xff09;。 # 这些数据点包含时间戳、测量&#xff08;measurement&#xff09;、标签&#xff08;tags&#xff09;和字段&#xff08;fields&#xff09;等信息。 # 以下是INSERT语句的基本语法 INSE…

C++面试:内存溢出、内存泄漏的原因与解决

目录 内存溢出&#xff08;Memory Overflow&#xff09; 内存溢出介绍 解决内存溢出问题的方法 内存泄漏&#xff08;Memory Leak&#xff09; 内存泄露基础 解决内存泄漏问题的方法 内存溢出&#xff08;Memory Overflow&#xff09; 内存溢出介绍 内存溢出是指程序在执…

第6.4章:StarRocks查询加速——Colocation Join

目录 一、StarRocks数据划分 1.1 分区 1.2 分桶 二、Colocation Join实现原理 2.1 Colocate Join概述 2.2 Colocate Join实现原理 三、应用案例 注&#xff1a;本篇文章阐述的是StarRocks-3.2版本的Colocation Join 官网文章地址&#xff1a; Colocate Join | StarRoc…

Rust所有权--与go对比学

如何拿返回值&#xff0c;如何不传递所有权就更改原值&#xff1f;如果想操作更改元变量要怎么做呢&#xff1f; 分别执行以下go代码&#xff1a; func main() {var a 10//calc1(a)//a calc_return(a)calc2(&a)a 100calc3(&a)fmt.Println(a) } func calc1(num int…

SQL Server 连接池相关内容

查看最大连接数 SELECT MAX_CONNECTIONS查看指定数据库的连接数 SELECT * FROM master.dbo.sysprocesses WHERE dbid IN ( SELECT dbid FROM master.dbo.sysdatabases WHERE NAMEDB_WMS_KZJ )获取当前SQL服务器所有的连接详细信息 SELECT * FROM sysprocesses获取自上次启动…

五大方法教你如何分分钟构造百万测试数据!

在测试的工作过程中&#xff0c;很多场景是需要构造一些数据在项目里的&#xff0c;方便测试工作的进行&#xff0c;构造的方法有很多&#xff0c;难度和技术深度也不一样。本文提供方法供你选择。 在测试的工作过程中&#xff0c;很多场景是需要构造一些数据在项目里的&#…

Centos服务器部署前后端项目

目录 准备工作1. 准备传输软件2. 连接服务器 部署Mysql1.下载Mysql(Linux版本)2. 解压3. 修改配置4. 启动服务另一种方法Docker 部署后端1. 在项目根目录中创建Dockerfile文件写入2. 启动 部署前端1. 在项目根目录中创建Dockerfile文件写入2. 启动 准备工作 1. 准备传输软件 …

全网唯一基于共享内存的C++ RPC框架

首先声明&#xff1a;我不是标题党&#xff0c;我是在找遍全网&#xff0c;没有找到一个基于共享内存实现、开源且跨平台的C RPC框架之后&#xff0c;才着手开发的这个框架。 项目地址&#xff1a;https://github.com/winsoft666/veigar 1. Veigar Veigar一词来源于英雄联盟里…

Nacos服务发现及其其他工具

1、什么是Nacos的服务发现功能 在微服务架构中&#xff0c;服务发现功能允许服务提供者&#xff08;服务实例&#xff09;将自己注册到Nacos服务器&#xff0c;同时服务消费者&#xff08;客户端&#xff09;能够通过Nacos服务器发现可用的服务实例。这样&#xff0c;服务消费…

2024年湖北省事业单位考试报名流程图解

⏰ 时间安排 ✔️ 注册&#xff1a;2024年2月19日至2月27日15:00 ✔️ 报名&#xff1a;2024年2月21日9:00至2月27日17:00 ✔️ 资格审查&#xff1a;2024年2月21日9:00至2月28日9:00 ✔️ 缴费确认&#xff1a;2024年2月28日9:00至3月1日24:00 ✔️ 岗位调整和改报&#…

数据结构与算法:图形数据结构

1. 图的基本概念和表示方法 图是一种由节点和边组成的非线性数据结构&#xff0c;用于描述事物之间的关系。在计算机科学中&#xff0c;图是一种十分重要的数据结构&#xff0c;广泛应用于各种领域&#xff0c;如网络分析、路径规划等。本节将介绍图的基本概念和两种常见的表示…

C++知识点总结(22):模拟算法

一、概念 模拟算法 根据题目描述进行筛选提取关键要素&#xff0c;按需求书写代码解决实际问题的算法。 二、步骤 1、提取题目的关键要素 2、根据关键要素的需求完成代码 三、关键要素 1、题目目的 2、样例的执行逻辑&#xff08;样例分析&#xff09; 3、数据范围&#xff08;…