IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Eureka的理解和使用 -> 正文阅读

[Java知识库]Eureka的理解和使用

一、概述

Eureka是Netflix影视公司出品的一套成熟老套的微服务技术,用于注册中心,以后出来的consul、zookeeper和Nacos多少会借鉴一点Eureka的相关思想和技术。

二、思想

1、Eureka有两个组件:Eureka Client 和 Eureka Server ,Eureka Server 可以理解为是Eureka的服务端或者注册中心,保存注册的服务信息,Eureka Client可以理解为是Eureka的客户端或者是各个微服务模块,他们需要被其他的微服务模块调用和调用其他微服务的服务,需要将自己的元数据注册进Eureka Server服务端,即注册中心,这个过程也分别叫做服务注册和服务发现

2、Eureka Client的注册表存放在本地缓存中,这使得Eureka Client每次请求不需要都去Eureka Server拿数据。而Eureka Client是没有本地缓存的,这使得注册表中的数据只能存放在内存中,所以,心跳也只能在内存中完成。

三、功能

Euraka的主要功能其实当作注册中心使用。但是它还有其他的功能:负载均衡、认证、健康检测等等。
重要的功能有:健康检测和自我保护机制

下面通过代码来分别实现健康检测和自我保护机制。
环境搭建-客户端

yaml文件:
spring:
  application:
    name: eureka-client
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
    healthcheck:
      enabled: true
  instance:
    hostname: STORES
    lease-expiration-duration-in-seconds: 20  #诉服务端,如果我20s之内没有给你发心跳,就代表我“死”了,将我踢出掉
    lease-renewal-interval-in-seconds: 10  #每间隔10s,向服务端发送一次心跳,证明自己依然”存活

启动类:
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@EnableEurekaClient
public class EurekaClientApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaClientApplication.class, args);
    }
    //整合actuator、实现健康检测
    @Bean
    public MyHealthIndicator11 myHealthIndicator(){
        return new MyHealthIndicator11();
    }
}

环境搭建-服务端

yaml:
spring:
  application:
    name: eureka-service
server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    healthcheck:
      enabled: true
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
  server:
    enable-self-preservation: false
    eviction-interval-timer-in-ms: 5000

启动类:
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

搭建好环境后,我们看看Eureka的健康检查,Eureka的健康检查是通过整个spring boot- autuator实现的,然后在配置文件中设置healthcheck属性即可。官网中是这么说的:如果只需要开启健康检查,只需要在配置文件中设置healthcheck,如果想自定义实现更多的健康检测功能,需要实现HealthCheckHandle健康检查处理器。这个类的作用其实就是将健康状态保存到内存,状态一改变就重新向服务端注册。
我们自定义一个HealthIndicator和一个HealthCheckHandle的实现类。
HealthIndicator实现类负责每次心跳检测就加一、当为5次后将微服务的健康状态改为DOWN,然后HealthCheckHandle实现类从HealthIndicator实现类中拿到健康状态,重新向服务端注册信息。代码如下:

@Component
public class MyHealthIndicator11 implements HealthIndicator {
    private int healthIndicatorErrorCount;

    private int healthIndicatorCount;

    private boolean hasError=false;

    @Override
    public Health health(){
        if(!hasError){
            healthIndicatorCount++;
//每检测5次,就返回DOWN
            if(healthIndicatorCount%2==0){
                hasError=true;
            }
        }else{
//DOWN计数10次就UP
            healthIndicatorErrorCount++;
            if(healthIndicatorErrorCount>10){
                hasError=false;
                healthIndicatorErrorCount=0;
            }
        }

        if(hasError){
            return new Health.Builder(Status.DOWN).build();
        }
        return new Health.Builder(Status.UP).build();

    }
}

@Component
public class MyHealthHealthCheckHandler implements HealthCheckHandler {
    @Autowired
    private MyHealthIndicator11 myHealthIndicator;
    @Override
    public InstanceInfo.InstanceStatus getStatus(InstanceInfo.InstanceStatus currentStatus){
        Status status=myHealthIndicator.health().getStatus();
        if(status== Status.UP){
            return InstanceInfo.InstanceStatus.UP;
        }else{
            return InstanceInfo.InstanceStatus.DOWN;
        }
    }
}

@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@EnableEurekaClient
public class EurekaClientApplication {

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


    //整合actuator、实现健康检测
    @Bean
    public MyHealthIndicator11 myHealthIndicator(){
        return new MyHealthIndicator11();
    }
}

刚开启时
在这里插入图片描述
五次心跳时间后
在这里插入图片描述
Eureka客户端五次心跳后,这个客户端的服务状态就变为DOWN了,重新向服务端注册,打开localhost:8761查看注册的微服务就能看到改变后的状态。

下面讲一讲Eureka的自我保护机制,这也是Eureak高可用的原因。自我保护机制的意思是Eureka的微服务由于某种原因不可用时,注册中心中的数据不会剔除,Euraka会认为这个微服务在未来某个时间能再可用。
Eureka默认是开启自我保护机制的。如果需要关闭掉,可以使用enable-self-preservation属性关闭。

下面测验一下
Eureka Server端
在这里插入图片描述
分别开启服务端和客户端后
在这里插入图片描述
关闭客户端,刷新页面后
在这里插入图片描述
客户端只要一关闭,马上注册中心中该客户端注册的信息就没有了。

Euraka还有其他的小功能,比如服务端能通过EurekaClient拿到该注册中心中注册的所有相关信息。

@RestController
public class EurekaClientController {
    @Qualifier("eurekaClient")
    @Autowired
    private EurekaClient eurekaClient;

    @RequestMapping("fa")
    public String serviceUrl() {
        Set<String> set = eurekaClient.getAllKnownRegions();
        Iterator<String> it = set.iterator();
        String res = "hello";
        while(it.hasNext()){
            res = it.next();
            break;
        }
        return res;
    }
}

四、细节

1、Eureaka客户端默认是半分钟发送一次心跳。

2、为什么注册服务会很慢?官网中有解释:客户端向服务端注册,需要发送心跳,默认是30秒,在实例、服务器和客户端的本地缓存中都具有相同的元数据之前,客户端无法发现服务,所以,可能需要三次心跳。你可以设置leaseRenewalIntervalInSeconds属性来改变心跳间隔时间,但是建议还是使用默认的30秒

3、刷新客户端:默认情况下Eureka Client是开启刷新功能的。当刷新发生时,客户端将从Eureka服务器注销,可能有一段时间,给定服务的所有实例都不可用,我们可以通过eureka.client.refresh.enable属性关闭自动刷新功能。

借鉴了https://www.cnblogs.com/li3807/p/8676401.html,同时,如有差错,忘不吝赐教!

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-03-17 21:56:42  更:2022-03-17 22:00:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:44:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码