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

 更新时间:2020年10月09日 10:42:33   作者:Gogym  
这篇文章主要介绍了解决zuulGateway网关添加路由异常熔断问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

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网关添加路由异常熔断问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java Selenide 简介与用法

    Java Selenide 简介与用法

    Selenium 是目前用的最广泛的Web UI 自动化测试框架,本文给大家介绍下Java Selenide使用,感兴趣的朋友一起看看吧
    2022-01-01
  • Java抽奖抢购算法

    Java抽奖抢购算法

    这篇文章主要为大家详细介绍了Java抽奖抢购算法,ava实现的抽奖抢购算法,用数据库行锁实现,支持集群,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • Java缓存ehcache的使用步骤

    Java缓存ehcache的使用步骤

    这篇文章主要介绍了Java缓存ehcache的使用步骤,文中有非常详细的代码示例,对正在学习java的小伙伴们有很好的帮助,需要的朋友可以参考下
    2021-05-05
  • SpringBoot集成Jasypt敏感信息加密的操作方法

    SpringBoot集成Jasypt敏感信息加密的操作方法

    这篇文章主要介绍了SpringBoot集成Jasypt加密敏感信息,包括敏感信息加密的作用,项目集成Jasypt方式详解,本文给大家介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • 深入浅出讲解Spring框架中依赖注入与控制反转及应用

    深入浅出讲解Spring框架中依赖注入与控制反转及应用

    依赖注入(Dependency Injection)和控制反转(Inversion of Control)是同一个概念。具体含义是:当某个角色(可能是一个Java实例,调用者)需要另一个角色(另一个Java实例,被调用者)的协助时,在 传统的程序设计过程中,通常由调用者来创建被调用者的实例
    2022-03-03
  • 使用log4j2打印mybatis的sql执行日志方式

    使用log4j2打印mybatis的sql执行日志方式

    这篇文章主要介绍了使用log4j2打印mybatis的sql执行日志方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Mybatis plus 配置多数据源的实现示例

    Mybatis plus 配置多数据源的实现示例

    这篇文章主要介绍了Mybatis plus 配置多数据源的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Java设置session超时的几种方式总结

    Java设置session超时的几种方式总结

    这篇文章主要介绍了Java设置session超时的几种方式总结的相关资料,需要的朋友可以参考下
    2017-07-07
  • 我赌你不清楚Spring中关于Null的这些事

    我赌你不清楚Spring中关于Null的这些事

    这篇文章主要介绍了我赌你不清楚Spring中关于Null的这些事,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • MyBatis基本实现过程

    MyBatis基本实现过程

    这篇文章主要介绍了Spring整合mybatis实现过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-07-07

最新评论