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