Hystrix系列-3-Hystrix的配置-通过代码构造配置

一、首先我们来实现一个HystrixCommand,示例代码如下:

package com.example.demo.hystrix.command;

import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;

import com.example.demo.utils.ObjectMapperInstance;
import com.example.demo.vo.User;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.netflix.hystrix.HystrixCommand;
import com.netflix.hystrix.HystrixCommandGroupKey;
import com.netflix.hystrix.HystrixCommandKey;
import com.netflix.hystrix.HystrixThreadPoolKey;

import lombok.Getter;

/**
 * 只需要集成HystrixCommand即可,并覆写父类中的相应方法即可
 * @author Administrator
 *
 */
public class UserHystrixCommond extends HystrixCommand<User>{
	
	@lombok.Setter @ Getter private String id;
	
	public UserHystrixCommond(String id) {
		super(Setter.withGroupKey(HystrixCommandGroupKey.Factory.asKey("UserCommandGroup"))
				.andCommandKey(HystrixCommandKey.Factory.asKey("userCommand"))
				.andThreadPoolKey(HystrixThreadPoolKey.Factory.asKey("userGroup")));
		this.id = id;
	}


	/**
	 * 覆写run方法,此处写业务逻辑
	 */
	@Override
	protected User run() throws Exception {
		System.out.println("command user: "+Thread.currentThread().getName()+"  is running......");
		CloseableHttpClient client = HttpClients.createDefault();
		HttpGet get = new HttpGet("http://localhost:7901/user/"+id);
		CloseableHttpResponse response = client.execute(get);
		HttpEntity entity = response.getEntity();
		String body = EntityUtils.toString(entity);
		ObjectMapper mapper = ObjectMapperInstance.getInstance();
		return mapper.readValue(body, User.class);
	}
	
	/**
	 * 服务降级方法,当调用服务发生异常时,会调用该降级方法
	 */
	@Override
	protected User getFallback() {
		System.out.println("进入fallback方法!");
		User u = new User();
		u.setUsername("刘先生");
		u.setId(1l);
		
		return u;
	}
}

下面,我们通过代码来看下,如何在代码中进行Hystrix的配置。

Hystrix是用Setter静态类来实现配置的,Setter类源码如下:

final public static class Setter {

     
Hystrix 中,可以通过在 HystrixCommand构造函数中传入 HystrixCommand.Setter 对象来配置命令的一些属性,其中就包括超时时间。如果要针对指定的类名和方法名来配置超时时间,可以在 HystrixCommand.Setter 对象中设置 commandKey 和 groupKey 属性,这样就可以针对指定的类名和方法名来配置超时时间了。 具体来说,可以通过如下方式来实现: 1. 在 HystrixCommand构造函数中,创建一个 HystrixCommand.Setter 对象。 2. 在 HystrixCommand.Setter 对象中,通过 withCommandKey 方法设置 commandKey 属性,该属性用于指定 HystrixCommand 的名称。 3. 在 HystrixCommand.Setter 对象中,通过 withGroupKey 方法设置 groupKey 属性,该属性用于指定 HystrixCommand 所属的分组名称。 4. 在 HystrixCommand.Setter 对象中,通过 withExecutionTimeoutInMilliseconds 方法来设置超时时间。 下面是一个示例代码: ```java HystrixCommand.Setter setter = HystrixCommand.Setter.withGroupKey(HystrixCommandGroupKey.Factory.asKey("MyGroup")) .andCommandKey(HystrixCommandKey.Factory.asKey("MyCommand")) .andThreadPoolKey(HystrixThreadPoolKey.Factory.asKey("MyThreadPool")) .andCommandPropertiesDefaults(HystrixCommandProperties.Setter() .withExecutionTimeoutInMilliseconds(1000)); MyCommand command = new MyCommand(setter); ``` 在上面的示例代码中,我们创建了一个 HystrixCommand.Setter 对象,并通过 withGroupKey 和 withCommandKey 方法分别设置了 HystrixCommand 所属的分组名称和命令名称。然后,通过 andCommandPropertiesDefaults 方法设置了超时时间为 1000 毫秒。最后,我们创建了一个 MyCommand 对象,并将 HystrixCommand.Setter 对象传入其构造函数中。 通过这种方式,我们就可以针对指定的类名和方法名来配置超时时间了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值