服务发现与注册:Eureka与Consul

在微服务架构中,服务发现与注册是一个非常重要的部分。通过服务发现机制,微服务能够相互找到并进行通信,而不需要了解彼此的具体地址。本文将详细介绍两种主流的服务发现与注册框架:Eureka和Consul,并提供相应的代码示例。

为什么需要服务发现与注册?

在传统的单体应用中,所有组件都运行在同一个进程中,彼此之间的调用是直接的。然而,在微服务架构中,应用被拆分为多个独立部署的服务,这些服务可能运行在不同的主机上。当一个服务需要调用另一个服务时,它需要知道对方的地址(IP和端口)。手动配置和管理这些信息是非常困难的,因此我们需要一种自动化的机制来解决这个问题。

服务发现与注册机制提供了一种解决方案,通过服务注册中心,所有的服务将自己的地址注册到这个中心,调用者可以通过服务注册中心来查找目标服务的地址,从而实现服务的动态发现。

Eureka

Eureka是Netflix开源的一个服务发现与注册框架,属于Spring Cloud生态系统的一部分。Eureka包含两个组件:Eureka Server和Eureka Client。

Eureka Server

Eureka Server是服务注册中心,所有的服务都会注册到这个中心。

搭建Eureka Server

首先,在你的Spring Boot项目中添加以下依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

创建一个Spring Boot应用主类,并添加@EnableEurekaServer注解:

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

application.yml中进行Eureka Server的配置:

server:port: 8761eureka:client:registerWithEureka: falsefetchRegistry: falseinstance:hostname: localhost

运行这个Spring Boot应用,你的Eureka Server就搭建好了。

Eureka Client

Eureka Client是需要注册到Eureka Server的服务。

搭建Eureka Client

在你的Spring Boot项目中添加以下依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

创建一个Spring Boot应用主类,并添加@EnableEurekaClient注解:

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

application.yml中进行Eureka Client的配置:

server:port: 8080eureka:client:serviceUrl:defaultZone: http://localhost:8761/eureka/

运行这个Spring Boot应用,它将自动注册到Eureka Server。

使用Eureka进行服务调用

在一个服务中通过RestTemplate来调用另一个服务:

@RestController
public class TestController {@Autowiredprivate RestTemplate restTemplate;@GetMapping("/test")public String test() {return restTemplate.getForObject("http://eureka-client-service/hello", String.class);}
}

确保在Spring Boot配置中启用负载均衡:

@Bean
@LoadBalanced
public RestTemplate restTemplate() {return new RestTemplate();
}

Consul

Consul是HashiCorp开源的一个服务发现与注册框架,同时还提供健康检查、KV存储等功能。Consul包含两个组件:Consul Server和Consul Client。

搭建Consul Server

首先,下载并安装Consul。可以参考Consul官方文档进行安装。

启动Consul Server:

consul agent -dev

Consul Client

Consul Client是需要注册到Consul Server的服务。

搭建Consul Client

在你的Spring Boot项目中添加以下依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>

创建一个Spring Boot应用主类:

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

application.yml中进行Consul Client的配置:

server:port: 8080spring:cloud:consul:host: localhostport: 8500discovery:serviceName: consul-client-service

运行这个Spring Boot应用,它将自动注册到Consul Server。

使用Consul进行服务调用

在一个服务中通过RestTemplate来调用另一个服务:

@RestController
public class TestController {@Autowiredprivate RestTemplate restTemplate;@GetMapping("/test")public String test() {return restTemplate.getForObject("http://consul-client-service/hello", String.class);}
}

确保在Spring Boot配置中启用负载均衡:

@Bean
@LoadBalanced
public RestTemplate restTemplate() {return new RestTemplate();
}

总结

通过这篇博客,我们了解了服务发现与注册的基本概念,并详细介绍了Eureka和Consul的使用方法。通过代码示例,我们可以看到如何搭建Eureka Server和Client,如何搭建Consul Client,以及如何通过RestTemplate进行服务调用。希望这篇博客能够帮助你更好地理解和使用服务发现与注册机制。


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

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

相关文章

elasticSearch快速了解

elasticSearch&#xff1a;经常用于搜索引擎&#xff0c;我们用的百度搜索和github上的搜索都是用的搜索引擎&#xff0c;它是对输入内容进行分析&#xff0c;然后查询&#xff0c;不像数据库模糊搜索的like一样必须含用你输入的全部内容。 elasticSearch优势&#xff1a;支持…

一文解决:你与该网站的连接不是私密连接,存在安全隐患

访问网页时&#xff0c;是不是会经常遇到网站不是私密连接的提示&#xff1f;当浏览器提示某个网页不安全时&#xff0c;这通常是因为网页使用的是非加密的HTTP协议&#xff0c;或者其HTTPS协议的SSL/TLS证书存在问题。 通常遇到这类网站时要注意&#xff0c;一来是网站未与证书…

`THREE.Line` 是 Three.js 中用于创建线段的类。

demo案例 THREE.Line 是 Three.js 中用于创建线段的类。以下是 THREE.Line 的详细说明&#xff0c;包括构造函数参数、输出、方法和属性。 构造函数 new THREE.Line(geometry, material, mode) geometry (THREE.BufferGeometry 或 THREE.Geometry): 定义线段的几何体。mater…

概率解码:SKlearn中模型的概率预测指南

概率解码&#xff1a;SKlearn中模型的概率预测指南 在机器学习中&#xff0c;概率预测是一种评估样本属于某个类别可能性的方法。这种预测方式不仅提供了分类结果&#xff0c;还给出了预测的置信度。Scikit-learn&#xff08;简称sklearn&#xff09;&#xff0c;作为Python中…

[图解]SysML和EA建模住宅安全系统-12-内部块图

1 00:00:00,580 --> 00:00:02,770 接下来我们来画流了 2 00:00:03,100 --> 00:00:05,050 首先第一个是站点状态 3 00:00:05,140 --> 00:00:08,130 从这里到这里&#xff0c;我们画一个过来 4 00:00:10,290 --> 00:00:11,890 这里流到这里 5 00:00:11,900 -->…

汉中茗茶小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;管理员管理&#xff0c;基础数据管理&#xff0c;茶叶管理&#xff0c;论坛管理&#xff0c;公告管理&#xff0c;茗茶历史管理 微信端账号功能包括&#xff1a;系统首页&#xff0c;茗茶信息&#xf…

探索 WebKit 的分享新境界:Web Share Target API 的深度解析

探索 WebKit 的分享新境界&#xff1a;Web Share Target API 的深度解析 在移动为先的网络世界中&#xff0c;Web Share Target API 为 Web 应用提供了一种简单而强大的方式&#xff0c;允许它们成为分享目标&#xff0c;接收来自其他应用或 Web 应用的内容。作为众多现代浏览…

mac怎么压缩pdf文件大小,mac压缩pdf文件大小不改变清晰度

在数字化时代&#xff0c;pdf格式因其良好的兼容性和稳定性&#xff0c;成为了文档分享和传输的首选。然而&#xff0c;随着文件内容的丰富&#xff0c;pdf文件的体积也越来越大&#xff0c;给存储和传输带来了不小的困扰。本文将揭秘几种简单有效的pdf文件压缩方法&#xff0c…

如何优化 PostgreSQL 中对于自关联表的查询?

文章目录 一、理解自关联表查询二、分析性能问题的可能原因&#xff08;一&#xff09;缺少合适的索引&#xff08;二&#xff09;大量数据的笛卡尔积&#xff08;三&#xff09;复杂的查询逻辑 三、优化策略及解决方案&#xff08;一&#xff09;创建合适的索引&#xff08;二…

OpenGL笔记七之顶点数据绘制命令和绘制模式

OpenGL笔记七之顶点数据绘制命令和绘制模式 —— 2024-07-07 杭州 下午 总结自bilibili赵新政老师的教程 code review! 文章目录 OpenGL笔记七之顶点数据绘制命令和绘制模式1.OpenGL版本号更改和编译更改2.GL_TRIANGLES模式绘制一个三角形、支持NFC坐标随窗口缩放2.1.三个点…

第二周:李宏毅机器学习笔记

第二周学习周报 摘要Abstract一、深度学习1.Backpropagation&#xff08;反向传播&#xff09;1.1 链式法则1.2 Forward pass&#xff08;前向传播&#xff09;1.3 Backward pass&#xff08;向后传播&#xff09;1.4 总结 2. Regression&#xff08;神奇宝贝案例&#xff09;2…

Redis常用命令——Set、Zset篇

文章目录 一、Set相关命令操作 SADD SMEMBERS SISMEMBER SCARD SPOP SMOVE SREM SINTER 与 SINTERSTORE SUNION 与 SUNIONSTORE SDIFF 与 SDIFFSTORE Set命令小结 二、Zset 相关命令操作 ZADD ZCARD ZCOUNT ZRANGE ZREVRANGE ZPOPMAX BZPOPMAX ZPOPMIN 与 BZPOPMIN ZRANK 与 …

MySQL事务隔离

MySQL事务隔离 前言锁共享锁&#xff08;Shared Lock&#xff09;排他锁&#xff08;Exclusive Lock&#xff09;行级锁&#xff08;Row-Level Lock&#xff09;表级锁&#xff08;Table-Level Lock&#xff09;快照读和当前读查看锁 事务事务的四个特性事务的并发问题事务的隔…

java中的jvm分为几种,各自的优缺点是什么,进来看看,必能凿壁偷光,眼前一亮

前言 Java虚拟机&#xff08;Java Virtual Machine, JVM&#xff09;是运行Java应用程序的核心组件&#xff0c;负责将Java字节码解释或编译为机器代码。不同的JVM实现提供了多种特性和性能优化&#xff0c;满足不同应用场景的需求。以下是一些主要的JVM实现及其各自的优缺点 …

手写深拷贝(Deep Copy)和浅拷贝(Shallow Copy)

在编程中&#xff0c;深拷贝&#xff08;Deep Copy&#xff09;和浅拷贝&#xff08;Shallow Copy&#xff09;是两个重要的概念&#xff0c;特别是在处理对象或数组时。它们的主要区别在于如何处理对象或数组中的引用类型&#xff08;如对象、数组等&#xff09;。 浅拷贝&am…

《Windows API每日一练》8.5 listbox控件

列表框是将一批文本字符串显示在一个具有滚动功能的方框中的控件。通过发送消息到列表框的窗口过程&#xff0c;程序可以添加或删除列表中的字符串。当列表框中的一个项目被选中时&#xff0c;列表框控件便发送 WM_COMMAND消息到其父窗口。然后父窗口确定哪个项目被选中。 本节…

2万字长文详解Ambari面试题及参考答案

目录 Ambari的主要功能是什么? Ambari如何与Hadoop生态系统中的其他组件交互? 解释Ambari中“蓝本”(Blueprints)的概念。 如何使用Ambari进行集群的监控和管理? Ambari支持哪些Hadoop版本? 在Ambari中,如何查看和管理服务日志? Ambari的安装过程涉及哪些主要步骤…

WEB开发-HTML页面更新部分内容

1 需求 2 接口 3 示例 在HTML页面中&#xff0c;如果你想要改变部分内容而不是整个页面&#xff0c;有几种方法可以实现这一目标&#xff0c;主要包括&#xff1a; JavaScript 的 DOM 操作 JavaScript允许你动态地修改HTML文档中的元素内容。你可以使用document.getElementB…

J024_打印电影的全部信息

一、需求描述 展示多部电影的信息。 电影信息包括&#xff1a;电影名称、电影得分、电影票价格。 二、代码实现 2.1 Movie类 package com.itheima.collection;public class Movie {//电影名称private String name;//电影得分private int score;//电影票价格private double…

11-云服务器处理单细胞转录组数据

目录 安装R及相关包 安装 shiny 进行安装包 安装BiocManager 安装Seurat包 网页端Rstudio需打开8787端口 Ubuntu上安装R包linux库缺失 关于服务器配置及相关处理可见:linux学习笔记_hx2024的博客-CSDN博客 安装R及相关包 8-阿里云服务器 ECS配置R及Studio Server-CS…