[toc]

处理问题:

  1. 对方服务超时了,调用者不能一直卡死等待,必须有服务降级。
  2. 对方服务down机了,调用者不能一直卡死等待,必须有服务降级。
  3. 对方服务OK,调用者自己出故障或有自我要求(自己的等待时间小于服务提供者),自己处理降级。

一、提供服务进行服务降级

1. 修改提供服务业务层增加hystrix注解

package org.learn.cloud.service;

import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixProperty;
import org.springframework.stereotype.Service;

import java.util.concurrent.TimeUnit;

@Service
public class PaymentService {

    //成功
    public String paymentInfo_OK(Integer id){
        return "线程池:"+Thread.currentThread().getName()+"   paymentInfo_OK,id:  "+id+"\t"+"哈哈哈"  ;
    }

    //失败
    @HystrixCommand(fallbackMethod = "paymentInfo_TimeOutHandler", commandProperties = {
            @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds",value = "3000")  //3秒钟以内就是正常的业务逻辑
    })
    public String paymentInfo_TimeOut(Integer id){
        // 模拟异常
//        int i = 10/0;
        // hystrix接受值为三秒内,模拟出错,时间为五秒
        int timeNumber = 5;
        try { TimeUnit.SECONDS.sleep(timeNumber); }catch (Exception e) {e.printStackTrace();}
        return "线程池:"+Thread.currentThread().getName()+"   paymentInfo_TimeOut,id:  "+id+"\t"+"呜呜呜"+" 耗时(秒)"+timeNumber;
    }

    //兜底方法
    public String paymentInfo_TimeOutHandler(Integer id){
        return "线程池:"+Thread.currentThread().getName()+"   系统繁忙, 请稍候再试  ,id:  "+id+"\t"+"哭了哇呜";
    }

}

image.png

2. 主启动类增加注解

@EnableCircuitBreaker

image.png

3. 测试

测试接口地址:localhost:7011/payment/hystrix/timeout/1
类型为:GET
测试结果为:
image.png

二、调用服务进行服务降级

1. 修改调用服务控制层增加hystrix注解

package org.learn.cloud.controller;

import com.netflix.hystrix.contrib.javanica.annotation.DefaultProperties;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import com.netflix.hystrix.contrib.javanica.annotation.HystrixProperty;
import lombok.extern.slf4j.Slf4j;
import org.learn.cloud.service.PaymentHystrixService;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

@RestController
@Slf4j
public class OrderHystrixController {

    @Resource
    private PaymentHystrixService paymentHystrixService;

    @Value("${server.port}")
    private String serverPort;

    @GetMapping("/consumer/payment/hystrix/ok/{id}")
    public String paymentInfo_OK(@PathVariable("id") Integer id){
        String result = paymentHystrixService.paymentInfo_OK(id);
        log.info("*******result:"+result);
        return result;
    }
    @GetMapping("/consumer/payment/hystrix/timeout/{id}")
    @HystrixCommand(fallbackMethod = "paymentTimeOutFallbackMethod",commandProperties = {
            @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds",value = "1500")  //3秒钟以内就是正常的业务逻辑
    })
    public String paymentInfo_TimeOut(@PathVariable("id") Integer id){
        String result = paymentHystrixService.paymentInfo_TimeOut(id);
        log.info("*******result:"+result);
        return result;
    }

    //兜底方法
    public String paymentTimeOutFallbackMethod(@PathVariable("id") Integer id){
        return "我是消费者80,对付支付系统繁忙请10秒钟后再试或者自己运行出错请检查自己,(┬_┬)";
    }

}

image.png

2. 主启动类增加注解

@EnableHystrix

image.png

3. 配置文件增加feign调用启用hystrix

feign:
  hystrix:
    enabled: true #如果处理自身的容错就开启。开启方式与生产端不一样。

3. 测试

测试接口地址:localhost:8011/consumer/payment/hystrix/timeout/1
类型为:GET
测试结果为:
image.png

三、进行全局代码配置,兜底方法冗余(服务降级,过渡阶段)

以调用者为例

1. 修改控制层,使用全局兜底方法

image.png

2. 重启项目进行测试

测试接口地址:localhost:8011/consumer/payment/hystrix/timeout/1
类型为:GET
测试结果为:
image.png

Q.E.D.


只有创造,才是真正的享受,只有拚搏,才是充实的生活。