SpringCloud(一)_健康自检

目的:监测Eureka客户端和服务器是否正常

需要依赖的jar: pom.xml

红色部分: springboot的actuator主要用于系统监控

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>org.crazyit.cloud</groupId>
	<artifactId>health-handler-provider</artifactId>
	<version>0.0.1-SNAPSHOT</version>

	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>Dalston.SR1</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>

	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-config</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-eureka</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-actuator</artifactId>
			<version>1.5.3.RELEASE</version>
		</dependency>
	</dependencies>

</project>

  

application.yml文件

配置 healthcheck之后,就会调用实现HealthCheckHandler的类,比如MyHealthCheckHandler

spring:
  application:
    name: health-handler-provider
eureka:
  instance:
    hostname: localhost
  client:
    healthcheck:
      enabled: true
    instanceInfoReplicationIntervalSeconds: 10
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

MyHealthCheckHandler模拟数据库是否可用的监测

return InstanceStatus.UP就会被Eureka服务器端监测到该client是down的状态
package org.crazyit.cloud;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.actuate.health.Status;
import org.springframework.stereotype.Component;

import com.netflix.appinfo.HealthCheckHandler;
import com.netflix.appinfo.InstanceInfo.InstanceStatus;

/**
 * 健康检查处理器
 * @author 杨恩雄
 *
 */
@Component
public class MyHealthCheckHandler implements HealthCheckHandler {

	@Autowired
	private MyHealthIndicator indicator;

	public InstanceStatus getStatus(InstanceStatus currentStatus) {
		Status s = indicator.health().getStatus();
		if(s.equals(Status.UP)) {
			System.out.println("数据库正常连接");
			return InstanceStatus.UP;
		} else {
			System.out.println("数据库无法连接");
			return InstanceStatus.DOWN;
		}
	}
}

  MyHealthIndicator监测数据数据库状态,是否可用

package org.crazyit.cloud;

import org.springframework.boot.actuate.health.Health;
import org.springframework.boot.actuate.health.Status;
import org.springframework.boot.actuate.health.Health.Builder;
import org.springframework.boot.actuate.health.HealthIndicator;
import org.springframework.stereotype.Component;

/**
 * 鍋ュ悍鎸囩ず鍣?
 * @author 鏉ㄦ仼闆?
 *
 */
@Component
public class MyHealthIndicator implements HealthIndicator {

	public Health health() {
		if(HealthController.canVisitDb) {
			// 鎴愬姛杩炴帴鏁版嵁搴擄紝杩斿洖UP
			return new Health.Builder(Status.UP).build();
		} else {
			// 杩炴帴鏁版嵁搴撳け璐ワ紝杩斿洖 out of service
			return new Health.Builder(Status.DOWN).build();
		}
	}
}

  HealthController修改数据库状态,输入http://localhost:8080/db/true即可开启数据库,而http://localhost:8080/db/false是关闭数据库

package org.crazyit.cloud;

import javax.servlet.http.HttpServletRequest;

import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HealthController {

	// 标识当前数据库是否可以访问
	static Boolean canVisitDb = false;

	@RequestMapping(value = "/db/{canVisitDb}", method = RequestMethod.GET)
	@ResponseBody
	public String setConnectState(@PathVariable("canVisitDb") Boolean canVisitDb) {
		this.canVisitDb = canVisitDb;
		return "当前数据库是否正常: " + this.canVisitDb;
	}
}

  

处理流程

1. 执行main方法,启动server

2. 自动读取application.yml文件,看到有配置healthcheck的状态为true,找实现HealthCheckHandler接口的类和重写的方法getStatus

3. MyHealthCheckHandler实现了HealthCheckHandler这个接口,通过MyHealthIndicator去查看数据库状态

4. MyHealthIndicator获取到数据库状态

5. HealthController专门为测试改变数据库状态而存在的

6.application.yml文件配置了instanceInfoReplicationIntervalSeconds: 10,所以每隔10s,就会访问实现HealthCheckHandler接口的类和重写的方法getStatus。

原文地址:https://www.cnblogs.com/zhougongjin/p/11076287.html

时间: 2024-08-10 07:51:19

SpringCloud(一)_健康自检的相关文章

linux常用命令---All

Linux命令大全 一.系统管理与设置; 二.用户和用户组管理; 三.磁盘管理; 四.文件和目录管理; 五.备份与压缩; 六.网络管理与相关应用; 七.vi/vim编辑器: 八.Shell编程 一.系统管理与设置 1.信息显示命令 # man & info  //帮助手册 # man 命令 //显示相应命令的帮助内容 # arch  //显示当前系统体系结构 # cal  //显示当前月份 # cal 2012  //显示2012年的月历 # cal 10 2012  //显示2012年10月的

疾病在突发前都有一些身体上的先兆

俗话说,病来如山倒.但其实,很多疾病在突发前都有一些身体上的先兆,只不过没有引起足够重视罢了.为了防微杜渐,让我们现在就来盘点一天当中不同阶段身体的不良感受,看看它们每时每刻都在诉说着什么.    早晨篇:头晕.头昏:早晨醒来后头晕.头昏,可能出现了颈椎骨质增生或血黏度高等疾病.    强烈的心慌饥饿感:凌晨4-5点钟醒来有强烈的心慌饥饿感,且疲乏无力,直到吃早餐后不舒适的感觉才逐渐消失,提示可能有糖尿病倾向.    清晨浮肿:如果在起床活动20分钟之后还不彻底消失,则提示可能有肾病或心脏病.棕

Linux命令------磁盘管理

# blkid  //列出当前系统中所有已挂载文件系统的类型 # blkid -s LABEL  //仅显示每个(指定)设备相匹配的标签 # blkid /dev/sda1  //查看/dev/sda1设备所采用的文件系统类型 # e2label device [newlabel]  //改变本地设备文件系统的label名称 # dd if=/dev/zero of=f1 bs=10MB count=2  //用虚拟文件f1检查配额情况 # dd if=/dev/sda of=/home/bac

01 在IDEA的同一目录下创建多个项目

1.打开IDEA,点击Create New Project 2.选择左边的Empty Project,点击next,创建一个空白的项目 3.给项目根目录命名,并选择项目存放路径 此时会弹出一个对话框,我们直接cancel就行. 4.给项目新建Module,对应的module就是相应的项目 我们选择新建一个空白的maven项目 按照上面同样的步骤,我们再建一个空白maven项目,这样我们就在"Eureka实例的健康自检"目录下建立了两个maven项目,同样的步骤我们可以在IDEA中创建更

springCloud(6):Eureka的自我保护模式、多网卡下的IP选择、Eureka的健康检查

一.Eureka的自我保护模式 进入自我保护模式最直观的体现就是Eureka Server首页的警告,如下图: 默认情况下,如果Eureka Server在一定时间内没有接收到某个微服务实例的心跳,Eureka Server将会注销该实例(默认90秒).但是当网络分区故障发生时,微服务与Eureka Server之间无法正常通信,这就可能变得非常危险了----因为微服务本身是健康的,此时本不应该注销这个微服务. Eureka Server通过"自我保护模式"来解决这个问题----当Eu

小D课堂 - 新版本微服务springcloud+Docker教程_汇总

小D课堂 - 新版本微服务springcloud+Docker教程_1_01课程简介 小D课堂 - 新版本微服务springcloud+Docker教程_1_02技术选型 小D课堂 - 新版本微服务springcloud+Docker教程_2_01传统架构演进到分布式架构 原文地址:https://www.cnblogs.com/wangjunwei/p/11434371.html

【发现你的用户需求】----需求自检六大问

经过这两天对需求模板的学习以及对实际案例的操作,相信你已经对如何寻找消费者需求有了很多新的认识.但是,新的问题又产生了:你干辛万苦找到的需求,消费者会买账吗? 找到那么多消费者需求,我到底选择哪一个,才最能打动消费者呢? 为了解决这个问题,我们增设了今天的训练,并且为你提供了需求自检六大问,在详细阅读这六大问并做过后面的训练后,我相信你会对究竟该为产品选择哪一个需求有更准确的判断. 这需求自检六大问分别是: 我是在帮消费者做他特別渴望的事情吗? 在我的产品之前,消费者的选择是什么,他存在不满吗?

SpringCloud Eureka参数配置项详解

SpringCloud Eureka参数配置项详解(转) Eureka涉及到的参数配置项数量众多,它的很多功能都是通过参数配置来实现的,了解这些参数的含义有助于我们更好的应用Eureka的各种功能,下面对Eureka的配置项做具体介绍,供大家参考. Eureka客户端配置       1.RegistryFetchIntervalSeconds 从eureka服务器注册表中获取注册信息的时间间隔(s),默认为30秒 2.InstanceInfoReplicationIntervalSeconds

NLP系列(4)_朴素贝叶斯实战与进阶(转)

http://blog.csdn.net/han_xiaoyang/article/details/50629608 作者: 寒小阳 && 龙心尘 时间:2016年2月. 出处:http://blog.csdn.net/han_xiaoyang/article/details/50629608 http://blog.csdn.net/longxinchen_ml/article/details/50629613 声明:版权所有,转载请联系作者并注明出处 1.引言 前两篇博文介绍了朴素贝叶