SpringCloud Hystrix实现容错和回退

Posted wuhen8866

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud Hystrix实现容错和回退相关的知识,希望对你有一定的参考价值。

为zuul添加回退

想要为Zuul添加回退,需要实现ZuulFallbackProvider接口,在实现类中,指定为哪个微服务提供回退,并提供一个ClientHttpResponse作为回退响应。
1.复制项目microservice-gateway-zuul,将ArtifactId修改为microservice-gateway-zuul-fallback。
2.编写zuul的回退类:

package com.xhx.springcloud.hystrix;
 
import com.alibaba.fastjson.JSONObject;
import org.springframework.cloud.netflix.zuul.filters.route.FallbackProvider;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.client.ClientHttpResponse;
import org.springframework.stereotype.Component;
 
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
 
/**
 * xuhaixing
 * 2018/6/12 21:36
 */
@Component
public class ZuulFallBack implements FallbackProvider 
    @Override
    public String getRoute() 
        return "eureka-feign";  //服务id,可以用* 或者 null 代表所有服务都过滤
    
 
    @Override
    public ClientHttpResponse fallbackResponse(String route, Throwable cause) 
        return new ClientHttpResponse() 
            @Override
            public HttpStatus getStatusCode() throws IOException 
                return HttpStatus.OK; //请求网关成功了,所以是ok
            
 
            @Override
            public int getRawStatusCode() throws IOException 
                return HttpStatus.OK.value();
            
 
            @Override
            public String getStatusText() throws IOException 
                return HttpStatus.OK.getReasonPhrase();
            
 
            @Override
            public void close() 
 
            
 
            @Override
            public InputStream getBody() throws IOException 
                JSONObject json =new JSONObject();
                json.put("state","501");
                json.put("msg","后台接口错误");
                return new ByteArrayInputStream(json.toJSONString().getBytes("UTF-8")); //返回前端的内容
            
 
            @Override
            public HttpHeaders getHeaders() 
                HttpHeaders httpHeaders = new HttpHeaders();
                httpHeaders.setContentType(MediaType.APPLICATION_JSON_UTF8); //设置头
                return httpHeaders;
            
        ;
    

以上是关于SpringCloud Hystrix实现容错和回退的主要内容,如果未能解决你的问题,请参考以下文章

SpringCloud之Hystrix容错处理

springCloud(11):使用Hystrix实现微服务的容错处理-简介与实现

SpringCloud——Hystrix服务容错(熔断与降级)

SpringCloud——Hystrix服务容错(熔断与降级)

SpringCloud——Hystrix服务容错(熔断与降级)

springcloud-hystrix断路器对微服务的容错处理