解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問(wèn)題
zuulGateway是spring cloud中很不錯(cuò)的組件,使用頻率很高。使用過(guò)程中偶爾可能遇到服務(wù)路由異常的情況,如果沒(méi)有異常熔斷,可能會(huì)造成應(yīng)用無(wú)響應(yīng),嚴(yán)重甚至造成系統(tǒng)雪崩。所以一般需要加上熔斷機(jī)制。
直接看代碼,很簡(jiǎn)單:
/*
* 文件名:ServerFallback.java 版權(quán):Copyright by www.poly.com 描述: 修改人:gogym 修改時(shí)間:2018年1月31日 跟蹤單號(hào): 修改單號(hào):
* 修改內(nèi)容:
*/
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服務(wù)id,如果需要所有調(diào)用都支持回退,則return "*"或return null
return "*";
}
@Override
public ClientHttpResponse fallbackResponse()
{
// ----------------返回前端-----------------------
return new ClientHttpResponse()
{
String responseStr = "{\"code\":10006,\"msg\":\"服務(wù)路由異常\"}";
@Override
public InputStream getBody()
throws IOException
{
return new ByteArrayInputStream(responseStr.getBytes("UTF-8"));
}
@Override
public HttpHeaders getHeaders()
{
HttpHeaders headers = new HttpHeaders();
// 和body中的內(nèi)容編碼一致,否則容易亂碼
headers.setContentType(MediaType.APPLICATION_FORM_URLENCODED);
return headers;
}
@Override
public int getRawStatusCode()
throws IOException
{
return HttpStatus.OK.value();
}
@Override
public HttpStatus getStatusCode()
throws IOException
{
/**
* 網(wǎng)關(guān)向api服務(wù)請(qǐng)求是失敗了,但是消費(fèi)者客戶(hù)端向網(wǎng)關(guān)發(fā)起的請(qǐng)求是OK的, 不應(yīng)該把a(bǔ)pi的404,500等問(wèn)題拋給客戶(hù)端
* 網(wǎng)關(guān)和api服務(wù)集群對(duì)于客戶(hù)端來(lái)說(shuō)是黑盒子
*/
return HttpStatus.OK;
}
@Override
public String getStatusText()
throws IOException
{
return HttpStatus.OK.getReasonPhrase();
}
@Override
public void close()
{
}
};
}
}
補(bǔ)充知識(shí):springcloud zuul 網(wǎng)關(guān)負(fù)載均衡路由到關(guān)閉節(jié)點(diǎn) 導(dǎo)致接口訪問(wèn)失敗問(wèn)題解決
springcloud 項(xiàng)目 相同服務(wù)部署兩個(gè)節(jié)點(diǎn) , 其中一個(gè)節(jié)點(diǎn)掛掉后, 路由到停止節(jié)點(diǎn)熔斷問(wèn)題 ,導(dǎo)致短時(shí)間內(nèi)接口訪問(wèn)成功率在50%
解決思路:
1、項(xiàng)目關(guān)閉 調(diào)用 鉤子函數(shù) 刪除 eureka 服務(wù)注冊(cè)(linux 項(xiàng)目關(guān)閉不要用kill -9 強(qiáng)制關(guān)閉鉤子函數(shù)不執(zhí)行)
DiscoveryManager.getInstance().shutdownComponent();
2、zuul網(wǎng)關(guān)開(kāi)啟重試功能
#是否開(kāi)啟重試功能 zuul.retryable=true <dependency> <groupId>org.springframework.retry</groupId> <artifactId>spring-retry</artifactId> </dependency>
這樣就可以實(shí)現(xiàn) springcloud項(xiàng)目生產(chǎn)與灰度的切換, 以及單節(jié)點(diǎn)掛掉 ,不影響項(xiàng)目接口訪問(wèn)問(wèn)題. 也就是可以實(shí)現(xiàn)不停服務(wù)上線項(xiàng)目
以上這篇解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- SpringCloud zuul 網(wǎng)關(guān)如何解決跨域問(wèn)題
- Spring Cloud Zuul路由網(wǎng)關(guān)服務(wù)過(guò)濾實(shí)現(xiàn)代碼
- SpringCloud Zuul網(wǎng)關(guān)功能實(shí)現(xiàn)解析
- SpringCLoud搭建Zuul網(wǎng)關(guān)集群過(guò)程解析
- SpringCloud網(wǎng)關(guān)組件zuul實(shí)例解析
- springcloud教程之zuul路由網(wǎng)關(guān)的實(shí)現(xiàn)
- Spring Cloud基于zuul實(shí)現(xiàn)網(wǎng)關(guān)過(guò)程解析
- Zuul 實(shí)現(xiàn)網(wǎng)關(guān)轉(zhuǎn)發(fā)的五種方式小結(jié)
相關(guān)文章
JDK1.8源碼下載及idea2021導(dǎo)入jdk1.8源碼的詳細(xì)步驟
這篇文章主要介紹了JDK1.8源碼下載及idea2021導(dǎo)入jdk1.8源碼的詳細(xì)步驟,在文章開(kāi)頭就給大家分享了JDK1.8源碼下載地址和下載步驟,告訴大家idea2021.1.3導(dǎo)入JDK1.8源碼步驟,需要的朋友可以參考下2022-11-11
java 實(shí)現(xiàn)讀取txt文本數(shù)據(jù)并以數(shù)組形式一行一行取值
今天小編就為大家分享一篇java 實(shí)現(xiàn)讀取txt文本數(shù)據(jù)并以數(shù)組形式一行一行取值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
在java中 利用匿名內(nèi)部類(lèi)進(jìn)行較簡(jiǎn)潔的雙括弧初始化的方法
本篇文章小編將為大家介紹,關(guān)于在java中 利用匿名內(nèi)部類(lèi)進(jìn)行較簡(jiǎn)潔的雙括弧初始化的方法,有需要的朋友可以參考一下2013-04-04
Java如何通過(guò)反射方式生成數(shù)據(jù)庫(kù)實(shí)體類(lèi)
這篇文章主要介紹了Java如何通過(guò)反射方式生成數(shù)據(jù)庫(kù)實(shí)體類(lèi)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
java微信掃描公眾號(hào)二維碼實(shí)現(xiàn)登陸功能
這篇文章主要為大家詳細(xì)介紹了PHP微信掃描公眾號(hào)二維碼實(shí)現(xiàn)登陸功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07

