解決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)者客戶端向網(wǎng)關(guān)發(fā)起的請(qǐng)求是OK的, 不應(yīng)該把a(bǔ)pi的404,500等問(wèn)題拋給客戶端 * 網(wǎng)關(guān)和api服務(wù)集群對(duì)于客戶端來(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-11java 實(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-04Java如何通過(guò)反射方式生成數(shù)據(jù)庫(kù)實(shí)體類(lèi)
這篇文章主要介紹了Java如何通過(guò)反射方式生成數(shù)據(jù)庫(kù)實(shí)體類(lèi)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12java微信掃描公眾號(hào)二維碼實(shí)現(xiàn)登陸功能
這篇文章主要為大家詳細(xì)介紹了PHP微信掃描公眾號(hào)二維碼實(shí)現(xiàn)登陸功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07