使用Eureka实现服务注册与发现的具体案例详解

devtools/2024/11/29 19:08:39/

1. Eureka 的基本概念

1.1 什么是 Eureka?

Eureka 是一个基于 REST 的服务注册和发现平台,主要分为以下两个组件:

  • Eureka Server:作为服务注册中心,负责维护服务实例信息。
  • Eureka Client:服务消费者与服务提供者都通过 Eureka Client 与 Eureka Server 交互。

Eureka 的核心目标是:

  • 服务动态注册与注销:服务启动后自动注册,停止时自动从注册中心移除。
  • 服务发现:通过注册中心查找可用服务。

1.2 Eureka 的工作原理

Eureka 的工作机制如下:

  1. 服务实例在启动时向 Eureka Server 注册。
  2. 服务消费者从 Eureka Server 获取服务列表以便调用。
  3. 服务实例定期发送心跳来保持注册状态,Eureka Server 持续监控实例的可用性。
  4. 服务实例停止时,向 Eureka Server 发送注销请求,或在心跳超时后被移除。

2. 实战:搭建基于 Eureka 的服务注册与发现系统

2.1 环境准备

  1. JDK 版本:8 或以上
  2. Spring Boot:2.5.x 或更高版本
  3. Maven:依赖管理工具

2.2 创建 Eureka Server

2.2.1 新建项目

通过 Spring Initializr 创建一个新的 Spring Boot 项目,选择以下依赖:

  • Spring Web
  • Eureka Server
2.2.2 配置 pom.xml

确保 pom.xml 包含以下 Eureka Server 依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
2.2.3 配置 application.yml

配置 Eureka Server 的基本信息:

server:port: 8761spring:application:name: eureka-servereureka:client:register-with-eureka: falsefetch-registry: falseserver:enable-self-preservation: false
2.2.4 启动 Eureka Server

在主类中添加 @EnableEurekaServer 注解,标记为 Eureka Server:

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {public static void main(String[] args) {SpringApplication.run(EurekaServerApplication.class, args);}
}

启动项目后,访问 http://localhost:8761,可看到 Eureka Server 的管理页面。

2.3 创建服务提供者(Provider)

2.3.1 新建项目

创建一个新的 Spring Boot 项目,选择以下依赖:

  • Spring Web
  • Eureka Client
2.3.2 配置 pom.xml

确保 pom.xml 包含 Eureka Client 依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2.3.3 配置 application.yml

配置服务提供者的基本信息:

server:port: 8081spring:application:name: provider-serviceeureka:client:service-url:defaultZone: http://localhost:8761/eureka/
2.3.4 实现业务接口

创建一个简单的 RESTful 接口:

@RestController
public class ProviderController {@GetMapping("/hello")public String sayHello() {return "Hello from Provider!";}
}

启动服务提供者后,Eureka Server 的管理页面中将显示 provider-service

2.4 创建服务消费者(Consumer)

2.4.1 新建项目

创建一个新的 Spring Boot 项目,选择以下依赖:

  • Spring Web
  • Eureka Client
  • Spring Cloud LoadBalancer
2.4.2 配置 pom.xml

添加所需依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
2.4.3 配置 application.yml

配置服务消费者的基本信息:

server:port: 8082spring:application:name: consumer-serviceeureka:client:service-url:defaultZone: http://localhost:8761/eureka/
2.4.4 调用服务

通过 RestTemplate 调用服务提供者:

@RestController
public class ConsumerController {@Autowiredprivate RestTemplate restTemplate;@GetMapping("/consume")public String consumeService() {String url = "http://provider-service/hello";return restTemplate.getForObject(url, String.class);}@Bean@LoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}
}

启动服务消费者后,访问 http://localhost:8082/consume,可调用服务提供者的接口。


3. 总结

通过上述案例,我们完整实现了基于 Eureka 的服务注册与发现功能。Eureka 提供了高效、动态的服务管理方式,在微服务架构中起到了核心作用。虽然 Netflix 宣布停止维护 Eureka,但其简单、直观的设计仍然是学习服务注册与发现的重要工具。此外,了解类似的服务注册工具(如 Consul、Zookeeper)也有助于构建更全面的知识体系。

希望本文的案例能帮助你快速上手 Eureka,并为构建微服务系统打下坚实的基础!


http://www.ppmy.cn/devtools/137993.html

相关文章

用Vue3.0 如何实现组件?实现一个 Modal应该怎么设计?

当然,Vue 3.0 提供了非常方便的组件化机制来实现像 Modal 这样的 UI 组件。实现一个 Modal 组件的基本设计思路是:通过一个控制显示与隐藏的 v-if 或 v-show,然后使用 props 接收外部控制参数,最后通过事件机制通知父组件进行交互。 以下是如何在 Vue 3.0 中实现一个基本的…

国产FPGA+DSP 双FMC 6U VPX处理板

高性能国产化信号处理平台采用6U VPX架构&#xff0c;双FMC接口国产V7 FPGA 国产多核 DSP 的硬件架构&#xff0c;可以完成一体化电子系统、有源相控阵雷达、电子侦察、MIMO 通信、声呐等领域的高速实时信号处理。 信号处理平台的组成框图如图 1 所示&#xff0c; DSP处理器采…

onnx报错解决-bert

一、定义 UserWarning: Provided key output for dynamic axes is not a valid input/output name warnings.warn( 案例 实体识别bert 案例 转transformers 模型到onnx 接口解读 二、实现 https://huggingface.co/docs/transformers/main_classes/onnx#transformers.onnx…

Sqoop的安装和配置,Sqoop的数据导入导出,MySQL对hdfs数据的操作

sqoop的安装基础是hive和mysql&#xff0c;没有安装好的同学建议去看一看博主的这一篇文章 Hive的部署&#xff0c;远程模式搭建&#xff0c;centos换源&#xff0c;linux上下载mysql。_hive-4.0.1-CSDN博客 好的那么接下来我们开始表演&#xff0c;由于hive是当时在hadoop03上…

Android so库的编译

在没弄明白so库编译的关系前,直接看网上博主的博文,常常会觉得云里雾里的,为什么一会儿通过Android工程cmake编译,一会儿又通过NDK命令去编译。两者编译的so库有什么区别? android版第三方库编译总体思路: 对于新手小白来说搞明白上面的总体思路图很有必…

PAT甲级 1056 Mice and Rice(25)

文章目录 题目题目大意基本思路AC代码总结 题目 原题链接 题目大意 给定参赛的老鼠数量为NP&#xff0c;每NG只老鼠分为一组&#xff0c;组中最胖的老鼠获胜&#xff0c;并进入下一轮&#xff0c;所有在本回合中失败的老鼠排名都相同&#xff0c;获胜的老鼠继续每NG只一组&am…

学习HTML第三十三天

学习文章目录 一.fieldset 与 legend 的使用&#xff08;了解&#xff09;二.表单总结三.框架标签 一.fieldset 与 legend 的使用&#xff08;了解&#xff09; fieldset 可以为表单控件分组、 legend 标签是分组的标题 二.表单总结 form表单&#xff1a; action 属性&#…

Spring Boot【四】

单例bean中使用多例bean 1.lookup-method方式实现 当serviceB中调用getServiceA的时候&#xff0c;系统自动将这个方法拦截&#xff0c;然后去spring容器中查找对应的serviceA对象然后返回 2.replaced-method&#xff1a;方法替换 我们可以对serviceB这个bean中的getServiceA…