解决zuulGateway网关添加路由异常熔断问题
zuulGateway是springcloud中很不错的组件,使用频率很高。使用过程中偶尔可能遇到服务路由异常的情况,如果没有异常熔断,可能会造成应用无响应,严重甚至造成系统雪崩。所以一般需要加上熔断机制。
直接看代码,很简单:
/*
*文件名:ServerFallback.java版权:Copyrightbywww.poly.com描述:修改人:gogym修改时间:2018年1月31日跟踪单号:修改单号:
*修改内容:
*/
packagecom.poly.zuul.fallback;
importjava.io.ByteArrayInputStream;
importjava.io.IOException;
importjava.io.InputStream;
importorg.springframework.cloud.netflix.zuul.filters.route.ZuulFallbackProvider;
importorg.springframework.http.HttpHeaders;
importorg.springframework.http.HttpStatus;
importorg.springframework.http.MediaType;
importorg.springframework.http.client.ClientHttpResponse;
importorg.springframework.stereotype.Component;
/**
*〈异常熔断〉
*
*@authorgogym
*@version2018年1月31日
*@seeServerFallback
*@since
*/
@Component
publicclassServerFallbackimplementsZuulFallbackProvider
{
@Override
publicStringgetRoute()
{
//api服务id,如果需要所有调用都支持回退,则return"*"或returnnull
return"*";
}
@Override
publicClientHttpResponsefallbackResponse()
{
//----------------返回前端-----------------------
returnnewClientHttpResponse()
{
StringresponseStr="{\"code\":10006,\"msg\":\"服务路由异常\"}";
@Override
publicInputStreamgetBody()
throwsIOException
{
returnnewByteArrayInputStream(responseStr.getBytes("UTF-8"));
}
@Override
publicHttpHeadersgetHeaders()
{
HttpHeadersheaders=newHttpHeaders();
//和body中的内容编码一致,否则容易乱码
headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
returnheaders;
}
@Override
publicintgetRawStatusCode()
throwsIOException
{
returnHttpStatus.OK.value();
}
@Override
publicHttpStatusgetStatusCode()
throwsIOException
{
/**
*网关向api服务请求是失败了,但是消费者客户端向网关发起的请求是OK的,不应该把api的404,500等问题抛给客户端
*网关和api服务集群对于客户端来说是黑盒子
*/
returnHttpStatus.OK;
}
@Override
publicStringgetStatusText()
throwsIOException
{
returnHttpStatus.OK.getReasonPhrase();
}
@Override
publicvoidclose()
{
}
};
}
}
补充知识:springcloudzuul网关负载均衡路由到关闭节点导致接口访问失败问题解决
springcloud项目相同服务部署两个节点,其中一个节点挂掉后,路由到停止节点熔断问题,导致短时间内接口访问成功率在50%
解决思路:
1、项目关闭调用钩子函数删除eureka服务注册(linux项目关闭不要用kill-9强制关闭钩子函数不执行)
DiscoveryManager.getInstance().shutdownComponent();
2、zuul网关开启重试功能
#是否开启重试功能 zuul.retryable=trueorg.springframework.retry spring-retry
这样就可以实现springcloud项目生产与灰度的切换,以及单节点挂掉,不影响项目接口访问问题.也就是可以实现不停服务上线项目
以上这篇解决zuulGateway网关添加路由异常熔断问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。