返回顶部
首页 > 资讯 > 后端开发 > Python >Spring Cloud Eureka基础应用及原理
  • 685
分享到

Spring Cloud Eureka基础应用及原理

2024-04-02 19:04:59 685人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录Eureka简介搭建Eureka服务注册中心搭建Eureka服务提供者搭建Eureka服务调用者Eureka服务注册和发现Eureka简介 Eureka这个词来源于古希腊语,意为

Eureka简介

Eureka这个词来源于古希腊语,意为“我找到了!我发现了!”。据传,阿基米德在洗澡时发现浮力原理,高兴得来不及穿上衣服,跑到街上大喊:“Eureka! ”。
在Netflix中,Eureka是一个RESTful风格的服务注册与发现的基础服务组件。Eureka由两部分组成,一个是Eureka Server,提供服务注册和发现功能,即我们上面所说的服务器端;另一个是Eureka Client,它简化了客户端与服务端之间的交互。Eureka Client会定时将自己的信息注册到Eureka Server中,并从Server中发现其他服务。Eureka Client中内置一个负载均衡器,用来进行基本的负载均衡。
下面我们将通过搭建一个简单的Eureka例子来了解Eureka的运作原理。

搭建Eureka服务注册中心

可以搭建包含Eureka Server依赖的Spring Boot项目。主要依赖如下:

在启动类中添加注解@EnableEurekaServer,代码如下所示:

@SpringBootApplication
//会为项目自动配置必须的配置类,标识该服务为注册中心
@EnableEurekaServer
public class DemoApplication {

    public static void main(String[] args) {
        springApplication.run(DemoApplication.class, args);
    }
}

在application.yml配置文件中添加以下配置,配置注册中心的端口和标识自己为Eureka Server:

server:
  port: 8761
#eureka配置--4部分
#1.dashboard WEB控制台
#2.server服务端配置--配置过期时间等
#3.client客户端配置--配置注册发现地址
#4.instance项目实例
eureka:
  #配置服务可视化默认开启
  dashboard:
    enabled: true
    path: /
  instance:
    hostname: localhost
  #这个是euraka暴漏给提供者和消费者服务发现注册用的
  client:
    service-url:
      #defaultZone: Http://localhost:8761/eureka不能写死
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka
    #是否注册到eureka上注册中心是不用把自己上床到自己的provider
    reGISter-with-eureka: false
    #是否需要到eureka上拉去服务路径--consumer需要
    fetch-registry: false

lnstanceld是Eureka服务的唯一标记,主要用于区分同一服务集群的不同实例。一般来讲,一个Eureka服务实例默认注册的Instanceld是它的主机名(即一个主机只有一个服务)。但是这样会引发一个问题,一台主机不能启动多个属于同一服务的服务实例。为了解决这种情况,spring-cloud-netflix-eureka提供了一个合理的实现,如上面代码中的Instanceld设置样式。通过设置random.value可以使得每一个服务实例的lnstanceld独一无二,从而可以唯一标记它自身。

Eureka Server既可以独立部署,也可以集群部署。在集群部署的信况下,EurekaServeri间会进行注册表信息同步的换作,这时被同步注册表信息的Eureka Server将会被其他同步注册表信息的Eureka Server称为peer。

请注意,上述配置中的service-url指向的注册中心为实例本身。通常来讲,一个Eureka Server也是一个Eureka Client,它会尝试注册自己,所以需要至少一个注册中心的URL来定位对等点peer。如果不提供这样一个注册端点,注册中心也能工作,但是会在日志中打印无法向peer注册自己的信息。在独立(Standalone) Eureka Server的模式下,Eureka Server一般会关闭作为客户端注册自己的行为。

Eureka Server与Eureka Client之间的联系主要通过心跳的方式实现。心跳(Heartbeat)即Eureka Client定时向Eureka Server汇报本服务实例当前的状态,维护本服务实例在注册表中租约的有效性。

Eureka Server需要随时维持最新的服务实例信息,所以在注册表中的每个服务实例都需要定期发送心跳到Server中以使自己的注册保持最新的状态.(数据一般直接保存在内存中)。为了避免Eureka Client在每次服务间调用都向注册中心请求依赖服务实例的信息,Eureka Client将定时从Eureka Server中拉取注册表中的信息,并将这些信息缓存到本地,用于服务发现。

启动Eureka Server后,应用会有一个主页面用来展示当前注册表中的服务实例信息并同时暴露一些基于HTTP协议的端点在/eureka路径下,这些端点将由EurekaClient用于注册自身、获取注册表信息以及发送心跳等。

搭建Eureka服务提供者

可以搭建包含Eurake Client依赖的Spring Boot项目。主要依赖有:

<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-netflix-eureka-client -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    <version>3.1.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <version>2.6.7</version>
</dependency>

启动类如下:

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

spring cloud的Finchley版本中,只要引入spring-cloud-starter-netflix-eureka-client的依赖,应用就会自动注册到Eureka Server,但是需要在配置文件中添加Eureka Server的地址。在application.yml添加以下配置:

# Eureka配置
eureka:
  instance:
     hostname: client
     instance-id: ${spring.application.name} :$ lvcap.application.instance_id:$ lspring.application.instance_id:$trandom value}}}
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
server :
  port : 8760
spring:
  application:
    rame: eureka-client

为服务提供者添加一个提供服务的接口,代码如下:

@RestContro11er
public class SayHe11oContro11er {
@RequestMapping(value = "/he11o/{name}")
public String sayHe11o(@PathVarivab1e("name") String name){
return "He11o,".concat(name).concat("! ");
}
}

上述接口将会向请求者返回打招呼的响应信息。

搭建Eureka服务调用者

可以搭建包含Eurake Client依赖的Spring Boot项目。主要依赖有:

<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-netflix-eureka-client -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    <version>3.1.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <version>2.6.7</version>
</dependency>

启动类代码如下:

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

在application.yml添加eureka-client相关配置,代码如下所示:

# Eureka配置
eureka:
  instance:
     hostname: client
     instance-id: ${spring.application.name} :$ lvcap.application.instance_id:$ lspring.application.instance_id:$trandom value}}}
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
server :
  port : 8765
spring:
  application:
    rame: eureka-client

添加一个AskController向eureka-client-service请求sayHello的服务。通过使用可以进行负载均衡的RestTemplate向eureka-client-service发起打招呼的请求,并直接返回对应的响应结果。具体代码如下所示:

@RestController
@Configuration
public class DemoController {
//注入本地服务名
@value("${spring.application. name}")
private string name;
@Autowired
RestTemplate restTemplate;
@RequestMapping(value = "/ask")
public string ask(){
//从eureka-client-service服务提供者中请求sayHello服务
string askHelloFromService = restTemplate.getForEntity("http ://EUREKA-CLIENT-SERVICE/hello/{name}", String.class,name).getBody();
return askHelloFromService;
}
//注入一个可以进行负载均衡的RestTemple用于服务间调用@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}

Eureka服务注册和发现

搭建好上述三个Eureka应用后,依次启动三个应用。
1.Eureka Server主页
访问Eureka Server的主页http://localhost:8761,可以看到下图所示的界面。
从图中可以看到以下信息:
-展示当前注册到Eureka server上的服务实例信息。
-展示Eureka Server运行环境的通用信息。
-展示Eureka Server实例的信息。

2.服务间调用
访问http:l/localhost:8762/ask,eureka-client将调用eureka-client-service的sayHello服务,向eureka-client-service传递服务名,等待eureka-client-service返回请求响应,响应结果如下:

Hello, eureka-client !

RestTemplate将根据服务名eureka-client-service通过预先从eureka-service缓存到本地的注册表中获取到eureka-client-service服务的具体地址,从而发起服务间调用。

3.与服务注册中心交换信息
DiscoveryClient来源于spring-cloud-client-discovery,是Spring Cloud中定义用来服务发现的公共接口,在Spring Cloud的各类服务发现组件中(如Netflix Eureka或Consul)都有相应的实现。它提供从服务注册中心根据serviceld获取到对应服务实例信息的能力。当一个服务实例拥有DiscoveryClient的具体实现时,就可以从服务注册中心中发现其他的服务实例。
在Eureka Client中注入DiscoveryClient,并从Eureka Server获取服务实例的信息。在chapter4-eureka-client添加一个ServicelnstanceRestController的controller ,如下所示:

@RestController
public class ServiceInstanceRestController {
@Autowired
private DiscoveryClient discoveryClient ;
@RequestMapping(" /service-instances/ {applicationName}")
public List<ServiceInstance> serviceInstancesByApplicationName(
@Pathvariable 
String applicationName(){
return this.discoveryClient.getInstances(applicationName);
}
}

启动应用后,访问地址http://localhost:8765/service-instancesleureka-client,获取应用名为eureka-client(服务本身)的服务实例元数据,结果如下所示:

Eureka中标准元数据有主机名、IP地址、端口号、状态页url和健康检查url等,这些元数据都会保存在Eureka Server的注册表中,Eureka Client根据服务名读取这些元数据,来发现和调用其他服务实例。元数据可以自定义以适应特定的业务场景,这些内容将在下一篇文章进行讲解。

到此这篇关于Spring Cloud Eureka基础应用的文章就介绍到这了,更多相关Spring Cloud  Eureka应用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Spring Cloud Eureka基础应用及原理

本文链接: https://lsjlt.com/news/149006.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Spring Cloud Eureka基础应用及原理
    目录Eureka简介搭建Eureka服务注册中心搭建Eureka服务提供者搭建Eureka服务调用者Eureka服务注册和发现Eureka简介 Eureka这个词来源于古希腊语,意为...
    99+
    2024-04-02
  • spring cloud eureka注册原理-注册失败填坑笔记
    目录写在前面Eureka Client注册过程分析遗留问题写在前面 我们知道Eureka分为两部分,Eureka Server和Eureka Client。Eureka Server...
    99+
    2024-04-02
  • Zookeeper的基础原理及应用场景
    本篇内容介绍了“Zookeeper的基础原理及应用场景”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!简单了...
    99+
    2024-04-02
  • spring cloud eureka 服务启动失败的原因分析及解决方法
    目录环境:错误log环境: <spring-boot-version>2.3.5.RELEASE</spring-boot-version> <s...
    99+
    2024-04-02
  • Spring Cloud原理以及核心组件详解
    目录概述一、业务场景介绍二、Spring Cloud核心组件:Eureka三、Spring Cloud核心组件:Feign四、Spring Cloud核心组件:Ribbon五、Spr...
    99+
    2023-03-21
    Spring Cloud原理详解
  • Spring Cloud原理及核心组件是什么
    本篇内容介绍了“Spring Cloud原理及核心组件是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!概述毫无疑问,Sprin...
    99+
    2023-07-05
  • Redis原理及基本应用
    CAP定理:    C:Consistency 一致性,分布式系统中数据备份节点都需要实时保持数据一致性;    A:Avai...
    99+
    2024-04-02
  • Spring Cloud Ribbon的使用原理解析
    目录一、概述1、Ribbon是什么2、Ribbon能干什么3、Ribbon现状4、未来替代方案5、架构说明二、RestTemplate 用法详解三、Ribbon核心组件IRule四、...
    99+
    2024-04-02
  • Spring BOOT AOP基础应用教程
    目录面试课题 Spring boot AOPSpring boot 动态代理AOP 切面基本知识自定义注解自定义注解如何在AOP引用面试课题 Spring boot AOP Spri...
    99+
    2024-04-02
  • 入门shell脚本基础及原理
    目录1.特殊变量2.内部环境变量3.整数以及字符判断3.1整数判断3.2字符测试4.文件判断5.read输入6.if判断7.案例选择判断8.for循环9.while循环10.深入练习1.写一个脚本,输入三个数字进行相应的...
    99+
    2022-06-04
    shell脚本原理 shell脚本入门
  • Spring Boot 底层原理基础深度解析
    目录1. 底层注解@Configuration2. 底层注解@Import3. 底层注解@Conditional1. 底层注解@Configuration @Configuratio...
    99+
    2024-04-02
  • react redux的原理以及基础使用讲解
    目录介绍为什么会使用 redux?什么时候该使用 redux?redux使用场景redux 作用工作流程使用1.下载2.创建仓库store骨架3.生成仓库4.参数函数的创建 redu...
    99+
    2022-11-13
    react redux原理 react redux使用 react redux
  • Spring AOP实现原理以及如何进行CGLIB应用
    本篇文章给大家分享的是有关Spring AOP实现原理以及如何进行CGLIB应用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。简介: AOP(Aspect Orien...
    99+
    2023-06-17
  • Spring Cloud-Feign服务调用的问题及处理方法
    概述: • Feign 是一个声明式的 REST 客户端,它用了基于接口的注解方式,很方便实现客户端配置。 • Feign 最初由 Netflix 公司提供...
    99+
    2024-04-02
  • Spring Cloud 中自定义外部化扩展机制原理及实战记录
    目录自定义PropertySource扩展PropertySourceLocatorSpring.factories编写controller测试阶段性总结SpringApplicat...
    99+
    2024-04-02
  • 【Spring Cloud Alibaba】(二)微服务调用组件Feign原理+实战
    系列目录 【Spring Cloud Alibaba】(一)微服务介绍 及 Nacos注册中心实战 本文目录 系列目录前言什么是RPC?Feign和OpenFeign都是什么?HTTP调用...
    99+
    2023-10-18
    微服务 spring cloud java spring 云原生
  • Promise的原理和基础用法介绍
    这篇文章主要介绍“Promise的原理和基础用法介绍”,在日常操作中,相信很多人在Promise的原理和基础用法介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Promis...
    99+
    2024-04-02
  • Javaweb基础入门requse原理与使用
    request对象是什么? Request对象的作用是与客户端交互,收集客户端的Form、Cookies、超链接,或者收集服务器端的环境变量。request对象是从客户端向服务器发出...
    99+
    2024-04-02
  • Python metaclass的原理及应用
    这篇文章主要介绍“Python metaclass的原理及应用”,在日常操作中,相信很多人在Python metaclass的原理及应用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python metacl...
    99+
    2023-06-02
  • 如何理解Go语言基础入门应用及常用命令
    本篇文章给大家分享的是有关如何理解Go语言基础入门应用及常用命令,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Go语言简介Go 是一门开源、支持并发、垃圾回收的编译型系统编程语...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作