SpringCloud Hystrix

Hystrix实现了 超时机制和断路器模式。

Hystrix是Netflix开源的一个类库,用于隔离远程系统、服务或者第三方库,防止级联失败,从而提升系统的可用性与容错性。主要有以下几点功能:

  1. 为系统提供保护机制。在依赖的服务出现高延迟或失败时,为系统提供保护和控制。
  2. 防止雪崩。
  3. 包裹请求:使用HystrixCommand(或HystrixObservableCommand)包裹对依赖的调用逻辑,每个命令在独立线程中运行。
  4. 跳闸机制:当某服务失败率达到一定的阈值时,Hystrix可以自动跳闸,停止请求该服务一段时间。
  5. 资源隔离:Hystrix为每个请求都的依赖都维护了一个小型线程池,如果该线程池已满,发往该依赖的请求就被立即拒绝,而不是排队等候,从而加速失败判定。防止级联失败。
  6. 快速失败:Fail Fast。同时能快速恢复。侧重点是:(不去真正的请求服务,发生异常再返回),而是直接失败。
  7. 监控:Hystrix可以实时监控运行指标和配置的变化,提供近实时的监控、报警、运维控制。
  8. 回退机制:fallback,当请求失败、超时、被拒绝,或当断路器被打开时,执行回退逻辑。回退逻辑我们自定义,提供优雅的服务降级。
  9. 自我修复:断路器打开一段时间后,会自动进入“半开”状态,可以进行打开,关闭,半开状态的转换。

隔离

将请求封装在HystrixCommand中,然后这些请求在一个独立的线程中执行,每个依赖服务维护一个小的线程池(或信号量),在调用失败或超时的情况下可以断开依赖调用或者返回指定逻辑

熔断

当HystrixCommand请求后端服务失败数量超过一定比例(默认50%), 断路器会切换到开路状态(Open). 这时所有请求会直接失败而不会发送到后端服务,断路器保持在开路状态一段时间后(默认5秒),自动切换到半开路状态(HALF-OPEN),这时会判断下一次请求的返回情况, 如果请求成功, 断路器切回闭路状态(CLOSED),否则重新切换到开路状态(OPEN)

降级

服务降级是指当请求后端服务出现异常的时候, 可以使用fallback方法返回的值

hystrix容错流程

在这里插入图片描述

1.每个请求都会封装到 HystrixCommand 中
2.请求会以同步或异步的方式进行调用(execure(),queue())
3.判断熔断器是否打开,如果打开,它会直接跳转到 8 ,进行降级
4.判断线程池/队列/信号量是否跑满,如果跑满进入降级步骤8
5.如果前面没有错误,就调用 run 方法,运行依赖逻辑
5.运行方法可能会超时,超时后从 5a 到 8,进行降级
6.运行过程中如果发生异常,会从 6b 到 8,进行降级
6.运行正常会进入 6a,正常返回回去,同时把错误或正常调用结果告诉 7 (Calculate Circuit Health)
7.Calculate Circuit Health它是 Hystrix 的大脑,是否进行熔断是它通过错误和成功调用次数计算出来的
8.降级方法(8a没有实现降级、8b实现降级且成功运行、8c实现降级方法,但是出现异常)
8a.没有实现降级方法,直接返回异常信息回去
8b.实现降级方法,且降级方法运行成功,则返回降级后的默认信息回去
8c.实现降级方法,但是降级也可能出现异常,则返回异常信息回去

hystrix独立使用

import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;

import com.netflix.hystrix.HystrixCommand;
import com.netflix.hystrix.HystrixCommandGroupKey;

public class HystrixTest extends HystrixCommand {

	protected HystrixTest(HystrixCommandGroupKey group) {
		super(group);
	}

	public static void main(String[] args) {
		/**
		 * execute():以同步阻塞方式执行run()。以demo为例,调用execute()后,
		 * hystrix先创建一个新线程运行run(),
		 * 	接着调用程序要在execute()调用处一直阻塞着,直到run()运行完成 
		 */
	//	System.out.println("result:" + hystrixTest.execute());
		
		/**
		 * queue():以异步非阻塞方式执行run()。以demo为例,
		 * 	一调用queue()就直接返回一个Future对象,
		 * 	同时hystrix创建一个新线程运行run(),
		 * 	调用程序通过Future.get()拿到run()的返回结果,
		 * 	而Future.get()是阻塞执行的
		 */
		Future<String> futureResult = new HystrixTest(HystrixCommandGroupKey.Factory.asKey("ext")).queue();
		String result = "";
		try {
			result = futureResult.get();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ExecutionException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		System.out.println("程序结果:"+result);
	}

	@Override
	protected Object run() throws Exception {
		// TODO Auto-generated method stub
		System.out.println("执行正常逻辑");
		int i = 1/0;
		return "ok";
	}

	@Override
	protected Object getFallback() {
		return "getFallbackgetFallback";
	}
}

整合Resttemplate

Service
@HystrixCommand(fallbackMethod = "back")
	public String alive() {
		// 自动处理URL
		RestTemplate restTemplate = new RestTemplate();
		
		String url ="http://user-provider/hello";
		String object = restTemplate.getForObject(url, String.class); 
		return object; 
	}
	
	public String back() { 
		return "请求失败处理";
	}
启动类

需要加上配置,feign不需要启动类加上这个,要在配置文件打开

@EnableCircuitBreaker

整合Feign

接口
@FeignClient(name = "user-provider",fallback = HelloBack.class)
public interface ConsumerApi {

	@RequestMapping(value = "/hello",method = RequestMethod.GET)
	public String hello(); 
}
实现
import org.springframework.stereotype.Component; 
@Component
public class HelloBack implements ConsumerApi{

	@Override
	public String alive() { 
		return "处理如果失败会到这里来处理逻辑";
	}
}
配置
feign.hystrix.enabled=true

开启dashboard

启动类
@EnableHystrixDashboard
引入依赖
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
		</dependency>
		
		<dependency>
		    <groupId>org.springframework.boot</groupId>
		    <artifactId>spring-boot-starter-actuator</artifactId>
		</dependency>
健康上报

http://localhost:8080/actuator/hystrix.stream

图形化

http://localhost:8080/hystrix

信号量隔离与线程隔离

默认情况下hystrix使用线程池控制请求隔离

线程池隔离技术,是用 Hystrix 自己的线程去执行调用;而信号量隔离技术,是直接让 tomcat 线程去调用依赖服务。信号量隔离,只是一道关卡,信号量有多少,就允许多少个 tomcat 线程通过它,然后去执行。

信号量隔离主要维护的是Tomcat的线程,不需要内部线程池,更加轻量级。
配置

hystrix.command.default.execution.isolation.strategy 隔离策略,默认是Thread, 可选Thread|Semaphore
thread 通过线程数量来限制并发请求数,可以提供额外的保护,但有一定的延迟。一般用于网络调用
semaphore 通过semaphore count来限制并发请求数,适用于无网络的高并发请求
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds 命令执行超时时间,默认1000ms
hystrix.command.default.execution.timeout.enabled 执行是否启用超时,默认启用true
hystrix.command.default.execution.isolation.thread.interruptOnTimeout 发生超时是是否中断,默认true
hystrix.command.default.execution.isolation.semaphore.maxConcurrentRequests 最大并发请求数,默认10,该参数当使用ExecutionIsolationStrategy.SEMAPHORE策略时才有效。如果达到最大并发请求数,请求会被拒绝。理论上选择semaphore size的原则和选择thread size一致,但选用semaphore时每次执行的单元要比较小且执行速度快(ms级别),否则的话应该用thread。
semaphore应该占整个容器(tomcat)的线程池的一小部分。

Feign下配置
hystrix.command.default.execution.isolation.strategy=SEMAPHORE
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Spring Cloud Hystrix是一个用于处理分布式系统的延迟和容错的库。它通过隔离服务之间的访问点,防止级联故障,并提供了一个备用方案,以便在出现故障时继续运行。Hystrix通过实现断路器模式来实现这些功能,这意味着它可以在服务之间建立一个断路器,以便在服务出现故障时自动切换到备用方案。 ### 回答2: Spring Cloud Hystrix是基于Netflix Hystrix的容错框架,为微服务提供了服务降级、服务熔断、服务限流等容错机制,以确保微服务在面临异常情况时,能够保持高可用性和稳定性。 在微服务架构中,服务之间的调用很容易受到网络波动、服务不可用、资源限制等影响,这时候如果不进行容错处理,就可能会导致整个系统崩溃。Spring Cloud Hystrix通过引入断路器的概念,可以提供一种优雅的容错处理方式。当某个服务出现故障或延迟时,断路器会立刻打开,停止对该服务的调用,降低对该服务的压力,保持系统的稳定性。 除了断路器外,Spring Cloud Hystrix还提供了线程池隔离、信号量隔离、缓存预处理等机制,以更好地保护系统。如果采用线程隔离,可以让请求在独立的线程中执行,从而防止请求的问题影响到其他请求。信号量隔离通过限制并发数,达到在负载高峰期或请求过多时,自我调节的目的。 在使用方面,Spring Cloud Hystrix也非常简单。只需在服务调用处添加@HystrixCommand注解,指定服务降级方法,就可以完成调用端的服务降级处理。对于其他Hystrix特性,也可以通过在配置文件中进行配置。 总而言之,Spring Cloud Hystrix为微服务架构提供了一种高效可靠的容错机制,可以在服务出现问题时,从容松手,保证系统的鲁棒性和扩展性。 ### 回答3: Spring Cloud Hystrix是一种开源的断路器模式实现,可用于构建分布式系统和微服务。它可以防止由于一个服务故障或超时导致整个系统崩溃。 在分布式系统中,一个服务的故障可能会导致整个系统的连锁反应。这就是为什么需要HystrixHystrix可以监视服务调用的结果,如果服务出现故障,它会强制断路器并替代其他服务并返回一个错误响应。 服务故障可能不仅仅是由于服务器故障,还包括超时,网络故障等原因。Hystrix 可以配置降级策略,当服务出现故障时,可以返回一些默认值或者备用数据,使得服务的调用方不至于完全失败。如果这些降级策略的执行时间过长,超出了阈值,那么Hystrix会自动熔断该服务,以免该服务继续产生故障影响到整个系统。 Hystrix可以同时监控多个服务,以避免整个系统受到单个服务故障的影响。如果某个服务出现问题,Hystrix会自动将该服务的请求转向其他可用的服务,以确保业务服务的高可用性。 在开发过程中,Hystrix虽然具有强大的监控能力,但同时也需要注意它会增加系统的负担,因此需要根据需求进行合理的配置。使用Hystrix需要在Spring Cloud应用中增加相应的依赖,同时在应用代码中使用@HystrixCommand注解对需要监控的服务进行定义。对服务的降级策略可以通过@Service注解中的fallback属性来定义。 总之,Hystrix提供了一种有力的方式来保证服务调用的稳定性,并确保系统的高可用性。它使得微服务架构更加健壮和高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值