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网关添加路由异常熔断问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持自学编程网。
- 本文固定链接: https://zxbcw.cn/post/197076/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)