Eureka基础知识

简介: Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务治理 在传统的rpc远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册。

什么是服务治理  



Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务治理

在传统的rpc远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,

管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册。


什么是服务注册与发现



Eureka采用了CS的设计架构,Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使用 Eureka的客户端连接到 Eureka Server并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。


在服务注册与发现中,有一个注册中心。当服务器启动的时候,会把当前自己服务器的信息 比如 服务地址通讯地址等以别名方式注册到注册中心上。另一方(消费者|服务提供者),以该别名的方式去注册中心上获取到实际的服务通讯地址,然后再实现本地RPC调用RPC远程调用框架,核心设计思想:在于注册中心,因为使用注册中心管理每个服务与服务之间的一个依赖关系(服务治理概念)。在任何rpc远程框架中,都会有一个注册中心(存放服务地址相关信息(接口地址))


6da022a05e03422ea212ce63b9813590.png


Eureka包含两个组件:Eureka Server和Eureka Client


Eureka Server提供服务注册服务


各个微服务节点通过配置启动后,会在EurekaServer中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观看到。


EurekaClient通过注册中心进行访问


是一个Java客户端,用于简化Eureka Server的交互,客户端同时也具备一个内置的、使用轮询(round-robin)负载算法的负载均衡器。在应用启动后,将会向Eureka Server发送心跳(默认周期为30秒)。如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,EurekaServer将会从服务注册表中把这个服务节点移除(默认90秒)


建Module



cloud-eureka-server7001


以前的老版本(当前使用2018)


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

现在新版本(当前使用2020.2)


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


yml配置文件



server:
  port: 7001
eureka:
  instance:
    hostname: localhost #eureka服务端的实例名称
  client:
    #false表示不向注册中心注册自己。
    register-with-eureka: false
    #false表示自己端就是注册中心,我的职责就是维护服务实例,并不需要去检索服务
    fetch-registry: false
    service-url:
    #设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址。
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/


主启动类



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

b72c755e8ab24476931072568ed21104.png


相关文章
|
4月前
|
缓存 负载均衡 监控
SpringCloud&Eureka理论与入门
SpringCloud&Eureka理论与入门
38 0
手把手教你搭建SpringCloud项目(六)Eureka实现服务发现
手把手教你搭建SpringCloud项目(六)Eureka实现服务发现
|
存储 缓存 运维
Eureka 核心概念解析
Eureka 核心概念解析
101 0
|
JSON 负载均衡 算法
9、Eureka、Feign、Ribbon的工作原理及项目实战
在前后端分离架构中,服务层被拆分成了很多的微服务,Spring Cloud中提供服务注册中心来管理微服务信息
161 0
9、Eureka、Feign、Ribbon的工作原理及项目实战
|
缓存 安全 NoSQL
SpringCloud入门学习之Eureka
SpringCloud入门学习之Eureka
177 0
SpringCloud入门学习之Eureka
|
监控 负载均衡 Dubbo
【Dubbo系列2】基础知识
这篇文章应该是月初就应该写的,当时看Dubbo相关的文章时一直提到RPC,所以就把RPC这块的知识先补齐。对于Dubbo,我目前需要对其整体初步了解,所以不会涉及到源码的内容,实战内容其实也很少,主要是有一个整体的初步人数,等后续用到Dubbo时,我再对其深入学习,包括Spring Cloud也是一样。 这篇文章参考敖丙的《dubbo系列 -rpc、dubbo基础知识》,我只对其进行重新整理。
122 0
【Dubbo系列2】基础知识
|
存储 负载均衡 NoSQL
SpringCloud基础知识超超级详细(1)
SpringCloud基础知识超超级详细(1)
173 0
SpringCloud基础知识超超级详细(1)
|
Java 微服务
SpringCloud基础知识超超级详细(2)
SpringCloud基础知识超超级详细(2)
132 0
SpringCloud基础知识超超级详细(2)
|
负载均衡 API
SpringCloud 源码剖析(二)实战 Eureka 本地集群搭建
SpringCloud 源码剖析(二)实战 Eureka 本地集群搭建
213 0
SpringCloud 源码剖析(二)实战 Eureka 本地集群搭建
|
缓存 算法
深入了解 Eureka 架构原理及实现(五)
深入了解 Eureka 架构原理及实现
198 0
深入了解 Eureka 架构原理及实现(五)