解决zuulGateway网关添加路由异常熔断问题
#代码知识 发布时间: 2026-01-12
zuulGateway是spring cloud中很不错的组件,使用频率很高。使用过程中偶尔可能遇到服务路由异常的情况,如果没有异常熔断,可能会造成应用无响应,严重甚至造成系统雪崩。所以一般需要加上熔断机制。

直接看代码,很简单:
/*
* 文件名:ServerFallback.java 版权:Copyright by www.poly.com 描述: 修改人:gogym 修改时间:2018年1月31日 跟踪单号: 修改单号:
* 修改内容:
*/
package com.poly.zuul.fallback;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import org.springframework.cloud.netflix.zuul.filters.route.ZuulFallbackProvider;
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;
/**
* 〈异常熔断〉
*
* @author gogym
* @version 2018年1月31日
* @see ServerFallback
* @since
*/
@Component
public class ServerFallback implements ZuulFallbackProvider
{
@Override
public String getRoute()
{
// api服务id,如果需要所有调用都支持回退,则return "*"或return null
return "*";
}
@Override
public ClientHttpResponse fallbackResponse()
{
// ----------------返回前端-----------------------
return new ClientHttpResponse()
{
String responseStr = "{\"code\":10006,\"msg\":\"服务路由异常\"}";
@Override
public InputStream getBody()
throws IOException
{
return new ByteArrayInputStream(responseStr.getBytes("UTF-8"));
}
@Override
public HttpHeaders getHeaders()
{
HttpHeaders headers = new HttpHeaders();
// 和body中的内容编码一致,否则容易乱码
headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
return headers;
}
@Override
public int getRawStatusCode()
throws IOException
{
return HttpStatus.OK.value();
}
@Override
public HttpStatus getStatusCode()
throws IOException
{
/**
* 网关向api服务请求是失败了,但是消费者客户端向网关发起的请求是OK的, 不应该把api的404,500等问题抛给客户端
* 网关和api服务集群对于客户端来说是黑盒子
*/
return HttpStatus.OK;
}
@Override
public String getStatusText()
throws IOException
{
return HttpStatus.OK.getReasonPhrase();
}
@Override
public void close()
{
}
};
}
}
补充知识:springcloud zuul 网关负载均衡路由到关闭节点 导致接口访问失败问题解决
springcloud 项目 相同服务部署两个节点 , 其中一个节点挂掉后, 路由到停止节点熔断问题 ,导致短时间内接口访问成功率在50%
解决思路:
1、项目关闭 调用 钩子函数 删除 eureka 服务注册(linux 项目关闭不要用kill -9 强制关闭钩子函数不执行)
DiscoveryManager.getInstance().shutdownComponent();
2、zuul网关开启重试功能
#是否开启重试功能 zuul.retryable=true <dependency> <groupId>org.springframework.retry</groupId> <artifactId>spring-retry</artifactId> </dependency>
这样就可以实现 springcloud项目生产与灰度的切换, 以及单节点挂掉 ,不影响项目接口访问问题. 也就是可以实现不停服务上线项目
以上这篇解决zuulGateway网关添加路由异常熔断问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
代码知识SEO上一篇 : SpringMVC Mock测试实现原理及实现过程详解
下一篇 : 解决IntelliJ IDEA中鼠标拖动选择为矩形区域问题
-
SEO外包最佳选择国内专业的白帽SEO机构,熟知搜索算法,各行业企业站优化策略!
SEO公司
-
可定制SEO优化套餐基于整站优化与品牌搜索展现,定制个性化营销推广方案!
SEO套餐
-
SEO入门教程多年积累SEO实战案例,从新手到专家,从入门到精通,海量的SEO学习资料!
SEO教程
-
SEO项目资源高质量SEO项目资源,稀缺性外链,优质文案代写,老域名提权,云主机相关配置折扣!
SEO资源
-
SEO快速建站快速搭建符合搜索引擎友好的企业网站,协助备案,域名选择,服务器配置等相关服务!
SEO建站
-
快速搜索引擎优化建议没有任何SEO机构,可以承诺搜索引擎排名的具体位置,如果有,那么请您多注意!专业的SEO机构,一般情况下只能确保目标关键词进入到首页或者前几页,如果您有相关问题,欢迎咨询!