SpringCloud:Eureka服务注册中心

这篇具有很好参考价值的文章主要介绍了SpringCloud:Eureka服务注册中心。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Eureka

Eureka是一个服务治理组件,它主要包括服务注册和服务发现,主要用来搭建服务注册中心。

使用Eureka的原因

在搭建微服务项目时遇到的三个问题:

  1. 服务消费者该如何获取服务提供者的地址信息?
  2. 如果有多个服务提供者,消费者该如何选择?
  3. 消费者如何得知服务提供者的健康状态?

Eureka的作用:

  1. 消费者该如何获取服务提供者具体信息?
    • 服务提供者启动时向eureka注册自己的信息
    • eureka保存这些信息
    • 消费者根据服务名称向eureka拉取提供者信息
  2. 如果有多个服务提供者,消费者该如何选择?
    • 服务消费者利用负载均衡算法,从服务列表中挑选一个
  3. 消费者如何感知服务提供者健康状态?
    • 服务提供者会每隔30秒向EurekaServer发送心跳请求,报告健康状态
    • eureka会更新记录服务列表信息,心跳不正常会被剔除
    • 消费者就可以拉取到最新的信息

Eureka的工作原理

  1. 首先存在下图中三个角色,其中 order-service(服务消费者 - 订单服务)、user-service(服务提供者 - 用户服务)统称为 eureka-client,也就是 eureka 的客户端。

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

  1. 接着,eureka-service 会分别去获取并注册服务提供者和服务消费者的 ip 地址和端口号,同时,order-service 也会通过 注册中心拉取 user-service 的信息(ip 和 端口号)如下图

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

  1. order-service 远程调用 user-service,首先会通过负载均衡,通过负载均衡算法(例如轮询)找到合适的 user-service ,如下图

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

  1. 之后,服务提供者中集群的每一个 service 都需要向注册中心每 30 秒发送一个心跳请求,这个请求不携带业务逻辑,只是用来表明自己还存在,没有挂掉~ 一旦超过一定时间,注册中心没有收到心跳包,注册中心就会认为这个服务下线(删除这个服务注册),同时 order-service 也就拉取不到这个服务的 IP 和端口号了~ 如下图

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

服务注册与部署

搭建注册中心

  1. 创建项目,引入spring-cloud-starter-netflix-eureka-server的依赖
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  1. 编写启动类,添加@EnableEurekaServer注解
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {

    public static void main(String[] args) {
        // 启动 Eureka 服务器
        SpringApplication.run(EurekaApplication.class, args);
    }
}
  1. 添加application.yml文件,编写下面的配置
server:
  port: 10086

spring:
  application:
    name: eurekaserver
        
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10086/eureka/

服务注册

  1. 在user-service项目引入spring-cloud-starter-netflix-eureka-client的依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    <version>4.0.2</version>
</dependency>
  1. 在application.yml文件原配置的基础下,添加下面的配置
server:
  port: 8080
  
spring:
  datasource:
    url: jdbc:mysql:///user
    username: root
    password: 83929317fan
    driver-class-name: com.mysql.cj.jdbc.Driver
  application:
    name: userserver
    
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10086/eureka/

服务部署

模拟注册多个服务:

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java
SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

服务启动后:

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

服务发现

启动类中创建RestTemplate,添加负载均衡注解:

SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java

服务类中修改url,用服务名代替ip、端口:
SpringCloud:Eureka服务注册中心,springcloud,spring cloud,eureka,spring,java文章来源地址https://www.toymoban.com/news/detail-807042.html

到了这里,关于SpringCloud:Eureka服务注册中心的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【微服务 SpringCloud】实用篇 · Eureka注册中心

    微服务(3) 假如我们的服务提供者 user-service部署了多个实例(不同实例,端口号不一致) ,如图: 大家思考几个问题: 我们刚才的编程,是写死在程序里的,ip和端口都是写死的, 这种硬编码的方式,之后改变ip和端口代码不就没法用了? order-service在发起远程调用的时候

    2024年02月08日
    浏览(40)
  • SpringCloud微服务技术栈的注册中心Eureka

    在微服务架构中,服务的数量庞大,而且每个服务可能会有多个实例。此时,需要一个中心化的地方来管理和维护各个服务的相关信息,这就是微服务治理中很重要的一环:服务注册与发现。其中,服务注册是指将提供服务的应用实例注册到注册中心,而服务发现则是指从注

    2023年04月09日
    浏览(53)
  • SpringCloud微服务 【实用篇】| Eureka注册中心、Ribbon负载均衡

    目录 一:Eureka注册中心 1. Eureka原理 2. 动手实践 ①搭建EurekaServer ②服务注册 ③服务发现  二:Ribbon负载均衡 1. 负载均衡原理 2. 负载均衡策略 3. 懒加载 tips:前些天突然发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家,感兴趣的同学可以

    2024年02月05日
    浏览(49)
  • # 从浅入深 学习 SpringCloud 微服务架构(三)注册中心 Eureka(3)

    段子手168 Eureka Server 可以通过运行多个实例并相互注册的方式实现高可用部署, Eureka Server 实例会彼此增量地同步信息,从而确保所有节点数据一致。 事实上,节点之间相互注册是 Eureka Server 的默认行为。 1)修改 eureka_server 子工程(子模块)中的 application.yml 文件 模拟两个

    2024年04月26日
    浏览(41)
  • 微服务springcloud 02 创建项目中的三个service子系统,springcloud中注册中心Eureka介绍和把三个系统注册到Eureka中

    item service项目 01.使用springboot创建项目 02.选择依懒项 在这里插入代码片 spring web 03.添加sp01-commons依赖 在pom.xml文件中 04.修改application.yml ItemServiceImpl 05.创建接口实现类和controller类 ItemController 注:Spring MVC接受参数的几个注解,controller类中使用的参数注解 注解@GetMapping()=@

    2024年02月09日
    浏览(62)
  • 基于SpringCloud的微服务架构学习笔记(2)注册中心Eureka和负载均衡Ribbon

    1.7.1 远程调用的问题 地址信息获取 : 服务消费者 如何获取 服务提供者 的 地址信息 (不能每次都写死): URL:http://localhost:8081/user/\\\"+order.getUserId() 多选一 :如果有多个服务提供者,消费者如何进行选择 监测健康状态 :消费者如何获知提供者的健康状态 1.7.2 eureka原理 地址

    2024年02月13日
    浏览(38)
  • SpringCloud--Eureka注册中心

              Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现。Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server并维持心跳连接。这样系统的维护人员就

    2024年01月17日
    浏览(39)
  • SpringCloud --- Eureka注册中心

    假如我们的服务提供者user-service部署了多个实例,如图 思考几个问题: order-service在发起远程调用的时候,该如何得知user-service实例的ip地址和端口? 有多个user-service实例地址,order-service调用时该如何选择? order-service如何得知某个user-service实例是否依然健康,是不是已经宕

    2023年04月24日
    浏览(41)
  • springcloud五大组件:Eureka:注册中心、Zuul:服务网关、Ribbon:负载均衡、Feign:服务调用、Hystix:熔断器

    Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的。 SpringCloud将它集成在其子项目spring-cloud-netflix中,以实现SpringCloud的服务发现功能。 Eureka包含两个组件:Eureka Server和Eure

    2024年04月10日
    浏览(44)
  • 【SpringCloud-1】注册中心-Eureka

    springcloud微服务,相对于dubbo这种SOA架构,提供了一站式的全套解决方案,什么意思呢?就是说springcloud不需要依赖其他组件,自己提供了全套的  常规项目需要使用的技术和解决问题的方案。  比如dubbo需要依赖zk作为注册中心,springcloud有自己的注册中心,对于其他如链路追

    2024年02月09日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包