码迷,mamicode.com
首页 > 编程语言 > 详细

Spring整合Hystrix

时间:2019-03-11 23:45:11      阅读:771      评论:0      收藏:0      [点我收藏+]

标签:超时   mod   回调   nbsp   切面   lis   end   turn   man   

1、添加maven依赖

<dependency>
    <groupId>com.netflix.hystrix</groupId>
    <artifactId>hystrix-core</artifactId>
    <version>1.5.18</version>
</dependency>
<dependency>
    <groupId>com.netflix.hystrix</groupId>
    <artifactId>hystrix-javanica</artifactId>
    <version>1.5.18</version>
</dependency>

2、配置切面

<aop:aspectj-autoproxy proxy-target-class="true" />
<bean class="com.netflix.hystrix.contrib.javanica.aop.aspectj.HystrixCommandAspect" />

3、编写controller类,并添加注解

@Controller
@RequestMapping
public class CommonController {
    /**
     * 主页
     * 
     * @return
     */
    @RequestMapping("/")
    public String home() {
        return "home.html";
    }

    /**
     * 配置2秒超时,超时后调用testFallback方法返回到error界面<br>
     * 当并发量比较大时,并非所有阻断或失败的请求都会走fallback方法,当处理线程忙不过来时,会直接抛出HystrixRuntimeException异常
     * 
     * @param mav
     * @param time 睡眠时间
     * @return
     */
    @HystrixCommand(groupKey = "groupTest", commandKey = "commandTest", fallbackMethod = "testFallback", commandProperties = {
            @HystrixProperty(name = "execution.timeout.enabled", value = "true"),
            @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "2000") })
    @RequestMapping("/test")
    public ModelAndView test(ModelAndView mav, @RequestParam(defaultValue = "1") int time) {
        try {
            Thread.sleep(1000 * time);
        } catch (Exception e) {
        }
        mav.setViewName("success.html");
        return mav;
    }

    /**
     * test访问熔断后回调页面
     * 
     * @param mav
     * @param time
     * @return
     */
    protected ModelAndView testFallback(ModelAndView mav, @RequestParam(defaultValue = "1") int time) {
        mav.setViewName("fallback.html");
        return mav;
    }
}

4、在webapp目录下添加fallback.html、success.html文件

5、访问http://127.0.0.1:8080/spring-hystrix-demo/test?time=0,浏览器正常进入success.html页面;

      访问http://127.0.0.1:8080/spring-hystrix-demo/test?time=5,连接超时,后台执行testFallback方法,浏览器进入fallback.html页面。

 

Spring整合Hystrix

标签:超时   mod   回调   nbsp   切面   lis   end   turn   man   

原文地址:https://www.cnblogs.com/zhi-leaf/p/10513999.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!