解决zuulGateway网关添加路由异常熔断问题

网友投稿 298 2022-11-18


解决zuulGateway网关添加路由异常熔断问题

zuulGateway是spring cloud中很不错的组件,使用频率很高。使用过程中偶尔可能遇到服务路由异常的情况,如果没有异常熔断,可能会造成应用无响应,严重甚至造成系统雪崩。所以一般需要加上熔断机制。

直接看代码,很简单:

/*

* 文件名:ServerFallback.java 版权:Copyright by 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

org.springframework.retry

spring-retry

这样就可以实现 springcloud项目生产与灰度的切换, 以及单节点挂掉 ,不影响项目接口访问问题. 也就是可以实现不停服务上线项目


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Mybatis如何实现延迟加载及缓存
下一篇:zuulGateway 通过filter统一修改返回值的操作
相关文章

 发表评论

暂时没有评论,来抢沙发吧~