栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

直接看代码,很简单:


 
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; 
 

@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
   {
    
    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项目生产与灰度的切换, 以及单节点挂掉 ,不影响项目接口访问问题. 也就是可以实现不停服务上线项目

以上这篇解决zuulGateway网关添加路由异常熔断问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/131209.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号