当前位置:首页 > 科技  > 软件

基于Spring Cloud Eureka,三分钟搞懂服务发现

来源: 责编: 时间:2023-12-24 10:14:13 415观看
导读1 介绍随着越来越多的企业采用微服务架构,服务发现成为了该架构中的重要组成部分。服务发现提供了一种自动在网络上发现和定位服务的方式,使得微服务能够相互通信。本文为大家介绍Spring Cloud Eureka,这是Netflix OSS提

1 介绍

随着越来越多的企业采用微服务架构,服务发现成为了该架构中的重要组成部分。服务发现提供了一种自动在网络上发现和定位服务的方式,使得微服务能够相互通信。本文为大家介绍Spring Cloud Eureka,这是Netflix OSS提供的用于服务发现的组件。Kkr28资讯网——每日最新资讯28at.com

2 什么是服务发现

在微服务架构中,每个微服务都是一个具有特定业务功能的独立应用程序。由于这些微服务需要相互通信以作为一个完整的应用程序运行,它们需要了解彼此的网络位置。服务发现在这里发挥作用,维护这些服务位置的记录,帮助它们相互发现并实现通信。Kkr28资讯网——每日最新资讯28at.com

3 什么是Spring Cloud Eureka

Spring Cloud Eureka是Spring Cloud Netflix项目的一部分,它是一个服务注册表,允许微服务注册自身并发现其他服务。实质上,它就像是微服务的电话簿,提供了服务与服务之间发现和注册的机制。Kkr28资讯网——每日最新资讯28at.com

4 设置Eureka服务器

首先,需要在pom.xml中添加spring-cloud-starter-netflix-eureka-server依赖项:Kkr28资讯网——每日最新资讯28at.com

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

然后,需要在Spring Boot应用程序的主要应用类中添加@EnableEurekaServer注解,启用Eureka服务器:Kkr28资讯网——每日最新资讯28at.com

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

最后,在application.properties文件中,定义Eureka服务器的属性:Kkr28资讯网——每日最新资讯28at.com

server.port=8761eureka.client.registerWithEureka=falseeureka.client.fetchRegistry=false

这里,server.port指定了Eureka服务器运行的端口。接下来的两个属性设置为false,目的是告诉Eureka服务器不要尝试把自身作为客户端注册到其他服务中心,并且不要从其他服务中心获取注册表信息。Kkr28资讯网——每日最新资讯28at.com

5 使用Eureka注册服务

接下来,向Eureka服务器注册一个简单的微服务。与设置Eureka服务器类似,首先在pom.xml文件中添加spring-cloud-starter-netflix-eureka-client依赖项:Kkr28资讯网——每日最新资讯28at.com

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

然后,在主要应用类中启用Eureka客户端:Kkr28资讯网——每日最新资讯28at.com

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

最后,在application.properties文件中,定义Eureka服务器的URL:Kkr28资讯网——每日最新资讯28at.com

eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka

现在,当此服务启动时,会向Eureka服务器注册自身。Kkr28资讯网——每日最新资讯28at.com

6 服务发现

到目前为止,已经将服务注册到Eureka中。现在看看如何发现服务。我们将使用Spring的RestTemplate和@LoadBalanced注解:Kkr28资讯网——每日最新资讯28at.com

@SpringBootApplication@EnableEurekaClientpublic class ExampleMicroserviceApplication {    @LoadBalanced    @Bean    public RestTemplate getRestTemplate() {        return new RestTemplate();    }    public static void main(String[] args) {        SpringApplication.run(ExampleMicroserviceApplication.class, args);    }}

@LoadBalanced将集成Ribbon负载均衡器,这是另一个Netflix组件。现在,为了消费一个服务,使用该服务的逻辑名称而不是硬编码URL:Kkr28资讯网——每日最新资讯28at.com

String response = restTemplate.exchange("http://example-microservice/service-endpoint", HttpMethod.GET, null, String.class);

Eureka和Ribbon将共同处理剩下的部分,发现服务并负载均衡任何请求。Kkr28资讯网——每日最新资讯28at.com

7 使用Eureka进行健康监控

Eureka的另一个功能是健康监控,它会跟踪注册的服务及其可用性。服务会发送心跳以告知Eureka它们正在运行。如果Eureka在一定时间内未收到心跳,它将注销该服务。Kkr28资讯网——每日最新资讯28at.com

Eureka服务器的仪表板可以通过http://localhost:8761访问,提供了一个可视化界面显示所有注册的服务及其详细信息。Kkr28资讯网——每日最新资讯28at.com

8 结语

本文介绍了服务发现的基础知识,探讨了Spring Cloud Eureka,并学习了如何使用其来注册和发现服务。本文还简要介绍了Eureka的健康监控功能。随着读者深入研究微服务,理解这些概念并有效使用诸如Spring Cloud Eureka之类的工具将对构建弹性和高效的应用程序有重要作用。Kkr28资讯网——每日最新资讯28at.com

这只是冰山一角。开发人员可以配置和自定义Eureka以更好地满足其需求,包括设置高可用性的Eureka服务器集群,调整健康监控设置,保护Eureka服务器等等。官方的Spring Cloud文档是探索这些高级主题的优秀资源。祝大家编码愉快!Kkr28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-53021-0.html基于Spring Cloud Eureka,三分钟搞懂服务发现

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Java常用的单元测试框架介绍

下一篇: 约 900GB 数据外泄,育碧正调查近期网络攻击事件

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 小米平板5 Pro 12.4简评:多专多能 兼顾影音娱乐的大屏利器

    疫情带来了网课,网课盘活了安卓平板,安卓平板市场虽然中途停滞了几年,但好的一点就是停滞的这几年行业又有了新的发展方向,例如超窄边框、高刷新率、多摄镜头组合等,这就让安卓
  • 7月安卓手机好评榜:三星S23Ultra好评率第一

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年7月1日至7月31日,仅限国内市场。第一名:三星Galaxy S23 Ultra好评率:95.71%在即将迎来新
  • 三言两语说透柯里化和反柯里化

    JavaScript中的柯里化(Currying)和反柯里化(Uncurrying)是两种很有用的技术,可以帮助我们写出更加优雅、泛用的函数。本文将首先介绍柯里化和反柯里化的概念、实现原理和应用
  • 微博大门常打开,迎接海外画师漂洋东渡

    作者:互联网那些事&ldquo;起猛了,我能看得懂日语了&rdquo;。&ldquo;为什么日本人说话我能听懂?&rdquo;&ldquo;中文不像中文,日语不像日语,但是我竟然看懂了&rdquo;&hellip;&hell
  • 华为HarmonyOS 4升级计划公布:首批34款机型今日开启公测

    8月4日消息,今天下午华为正式发布了HarmonyOS 4系统,在更流畅的前提下,还带来了不少新功能,UI设计也有变化,会让手机焕然一新。华为宣布,首批机型将会在
  • Android 14发布:首批适配机型公布

    5月11日消息,谷歌在今天凌晨举行了I/O大会,本次发布会谷歌带来了自家的AI语言模型PaLM 2、谷歌Pixel Fold折叠屏、谷歌Pixel 7a手机,同时发布了Androi
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
  • Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
Top