摘要:英文意思就是說提供一個回退機(jī)制當(dāng)路由后面的服務(wù)發(fā)生故障時。注意注解能注冊到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔?,該是一個復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。
SpringCloud(第 025 篇)Zuul 路由后面的微服務(wù)掛了后,Zuul 提供了一種回退機(jī)制來應(yīng)對熔斷處理
-
一、大致介紹1、在一些不穩(wěn)定因素導(dǎo)致路由后面的微服務(wù)宕機(jī)或者無響應(yīng)時,zuul 就會累計(jì)大量的請求,久而久之基本上所有的請求都會超時,但是請求鏈接數(shù)卻不斷的在增加,不斷的占用資源池不能結(jié)束知道超時消耗殆盡導(dǎo)致zuul微服務(wù)死機(jī),整體掛機(jī)消亡; 2、而 zuul 在這種情況下,提供一種很好的回退機(jī)制,針對大量請求時提供了友好的熔斷機(jī)制,確保在路由微服務(wù)修復(fù)前,盡量將過多的請求快速響應(yīng)返回,減輕zuul的壓力; 3、在本章節(jié),我們對上面發(fā)生的這種普遍現(xiàn)象做了一種簡單的回退處理,有效降低微服務(wù)的壓力,還可以友好的提示給前端用戶,或者調(diào)用方;二、實(shí)現(xiàn)步驟 2.1 添加 maven 引用包
2.2 添加應(yīng)用配置文件(springms-gateway-zuul-fallbacksrcmainresourcesapplication.yml)4.0.0 springms-gateway-zuul-fallback 1.0-SNAPSHOT jar com.springms.cloud springms-spring-cloud 1.0-SNAPSHOT org.springframework.cloud spring-cloud-starter-zuul org.springframework.cloud spring-cloud-starter-eureka
spring: application: name: springms-gateway-zuul-fallback server: port: 8200 eureka: datacenter: SpringCloud # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Data center 顯示信息 environment: Test # 修改 http://localhost:8761 地址 Eureka 首頁上面 System Status 的 Environment 顯示信息 client: service-url: defaultZone: http://admin:admin@localhost:8761/eureka healthcheck: # 健康檢查 enabled: true instance: prefer-ip-address: true instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}} ##################################################################################################### zuul: ignoredServices: springms-consumer-movie-ribbon-with-hystrix routes: springms-provider-user: /user/** ##################################################################################################### ##################################################################################################### # 打印日志 logging: level: root: INFO com.springms: DEBUG ##################################################################################################### ##################################################################################################### ribbon: ConnectTimeout: 3000 ReadTimeout: 60000 ##################################################################################################### ##################################################################################################### # 解決第一次請求報超時異常的方案,因?yàn)?hystrix 的默認(rèn)超時時間是 1 秒,因此請求超過該時間后,就會出現(xiàn)頁面超時顯示 : # # 這里就介紹大概三種方式來解決超時的問題,解決方案如下: # # 第一種方式:將 hystrix 的超時時間設(shè)置成 5000 毫秒 hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 5000 # # 或者: # 第二種方式:將 hystrix 的超時時間直接禁用掉,這樣就沒有超時的一說了,因?yàn)橛肋h(yuǎn)也不會超時了 # hystrix.command.default.execution.timeout.enabled: false # # 或者: # 第三種方式:索性禁用feign的hystrix支持 # feign.hystrix.enabled: false ## 索性禁用feign的hystrix支持 # 超時的issue:https://github.com/spring-cloud/spring-cloud-netflix/issues/768 # 超時的解決方案: http://stackoverflow.com/questions/27375557/hystrix-command-fails-with-timed-out-and-no-fallback-available # hystrix配置: https://github.com/Netflix/Hystrix/wiki/Configuration#execution.isolation.thread.timeoutInMilliseconds #####################################################################################################2.3 添加zuul回退處理類(springms-gateway-zuul-fallbacksrcmainjavacomspringmscloudfallbackCustomZuulFallbackHandler.java)
package com.springms.cloud.fallback; 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; import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStream; /** * 自定義Zuul回退機(jī)制處理器。 * * Provides fallback when a failure occurs on a route 英文意思就是說提供一個回退機(jī)制當(dāng)路由后面的服務(wù)發(fā)生故障時。 * * @author hmilyylimh * * @version 0.0.1 * * @date 2017/9/27 * */ @Component public class CustomZuulFallbackHandler implements ZuulFallbackProvider { /** * 返回值表示需要針對此微服務(wù)做回退處理(該名稱一定要是注冊進(jìn)入 eureka 微服務(wù)中的那個 serviceId 名稱); * * @return */ @Override public String getRoute() { return "springms-provider-user"; } @Override public ClientHttpResponse fallbackResponse() { return new ClientHttpResponse() { @Override public HttpStatus getStatusCode() throws IOException { return HttpStatus.BAD_REQUEST; } @Override public int getRawStatusCode() throws IOException { return HttpStatus.BAD_REQUEST.value(); } @Override public String getStatusText() throws IOException { return HttpStatus.BAD_REQUEST.getReasonPhrase(); } @Override public void close() { } /** * 當(dāng) springms-provider-user 微服務(wù)出現(xiàn)宕機(jī)后,客戶端再請求時候就會返回 fallback 等字樣的字符串提示; * * 但對于復(fù)雜一點(diǎn)的微服務(wù),我們這里就得好好琢磨該怎么友好提示給用戶了; * * @return * @throws IOException */ @Override public InputStream getBody() throws IOException { return new ByteArrayInputStream((getRoute() + " fallback").getBytes()); } @Override public HttpHeaders getHeaders() { HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); return headers; } }; } }2.4 添加zuul服務(wù)網(wǎng)關(guān)微服務(wù)啟動類(springms-gateway-zuul-fallbacksrcmainjavacomspringmscloudMsGatewayZuulFallbackApplication.java)
package com.springms.cloud; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.zuul.EnableZuulProxy; /** * Zuul 路由后面的微服務(wù)掛了后,Zuul 提供了一種回退機(jī)制來應(yīng)對熔斷處理。 * * 注意 EnableZuulProxy 注解能注冊到 eureka 服務(wù)上,是因?yàn)樵撟⒔獍?eureka 客戶端的注解,該 EnableZuulProxy 是一個復(fù)合注解。 * * @EnableZuulProxy --> { @EnableCircuitBreaker、@EnableDiscoveryClient } 包含了 eureka 客戶端注解,同時也包含了 Hystrix 斷路器模塊注解。 * * http://localhost:8150/routes 地址可以查看該zuul微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的serviceId。 * * @author hmilyylimh * * @version 0.0.1 * * @date 2017/9/27 * */ @SpringBootApplication @EnableZuulProxy public class MsGatewayZuulFallbackApplication { public static void main(String[] args) { SpringApplication.run(MsGatewayZuulFallbackApplication.class, args); System.out.println("【【【【【【 GatewayZuulFallback微服務(wù) 】】】】】】已啟動."); } }三、測試
/**************************************************************************************** 一、Zuul 路由后面的微服務(wù)掛了后,Zuul 提供了一種回退機(jī)制來應(yīng)對熔斷處理: 1、編寫 application.yml 文件,添加應(yīng)用程序的注解 EnableZuulProxy 配置; 2、啟動 springms-discovery-eureka 模塊服務(wù),啟動1個端口; 3、啟動 springms-provider-user 模塊服務(wù),啟動1個端口(application.yml 文件中的 appname 屬性不去掉的話,測試一是無法測試通過的); 4、啟動 springms-gateway-zuul-fallback 模塊服務(wù),啟動1個端口; 5、新起網(wǎng)頁頁簽,輸入 http://localhost:7900/simple/3 正常情況下是能看到 ID != 0 一堆用戶信息被打印出來; 6、新起網(wǎng)頁頁簽,然后輸入 http://localhost:8200/springms-provider-user/simple/3,正常情況下是能看到 ID != 0 一堆用戶信息被打印出來; 7、這個時候,停止 springms-provider-user 模塊服務(wù); 8、刷新 http://localhost:8200/springms-provider-user/simple/3 網(wǎng)頁,正常情況下會提示 “fallback” 字樣的字符串; ...... 等待大約兩分鐘左右 ......(微服務(wù)宕機(jī)默認(rèn)好像是90秒再連不上eureka服務(wù)的話,就會被eureka服務(wù)剔除掉) 9、待用戶微服務(wù)被踢出后,刷新 http://localhost:8200/springms-provider-user/simple/3 網(wǎng)頁,正當(dāng)情況下會提示 404 錯誤頁面,因?yàn)橛脩粑⒎?wù)由于宕機(jī)超過大約90秒后會自動被 eureka 服務(wù)器剔除掉,所以訪問網(wǎng)頁必然找不到服務(wù)路徑; 總結(jié):首先 Zuul 作為路由轉(zhuǎn)發(fā)微服務(wù),其也提供了一種熔斷機(jī)制,避免大量請求阻塞在路由分發(fā)處; 其次當(dāng)注冊進(jìn)入 eureka 服務(wù)治理發(fā)現(xiàn)框架后,一定時間后還沒有連上eureka時,這個時候eureka就會將這個宕機(jī)的微服務(wù)移除服務(wù)治理框架; ****************************************************************************************/四、下載地址
https://gitee.com/ylimhhmily/SpringCloudTutorial.git
SpringCloudTutorial交流QQ群: 235322432
SpringCloudTutorial交流微信群: 微信溝通群二維碼圖片鏈接
歡迎關(guān)注,您的肯定是對我最大的支持!!!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/70612.html
摘要:是一個相對比較新的微服務(wù)框架,年才推出的版本雖然時間最短但是相比等框架提供的全套的分布式系統(tǒng)解決方案。提供線程池不同的服務(wù)走不同的線程池,實(shí)現(xiàn)了不同服務(wù)調(diào)用的隔離,避免了服務(wù)器雪崩的問題。通過互相注冊的方式來進(jìn)行消息同步和保證高可用。 Spring Cloud 是一個相對比較新的微服務(wù)框架,...
摘要:第篇的過濾器的使用一大致介紹我們在學(xué)的時候,就有過濾器和攔截器的使用,而同樣也有過濾器的使用,本章節(jié)我們指在如何簡單使用。是否執(zhí)行該過濾器。說明需要過濾說明不要過濾過濾器的具體邏輯。請求的添加服務(wù)網(wǎng)關(guān)微服務(wù)啟動類的過濾器的使用。 SpringCloud(第 021 篇)Zuul 的過濾器 ZuulFilter 的使用 - 一、大致介紹 1、我們在學(xué) Spring 的時候,就有過濾器和攔...
摘要:地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。微服務(wù)已啟動使用提供和之間的綁定它使用正則表達(dá)式組來從提取變量然后注入到路由表達(dá)式中。 SpringCloud(第 022 篇)Zuul 網(wǎng)關(guān)微服務(wù)的 regexmapper 屬性測試, 類似測試 zuul 的自定義路徑規(guī)則一樣 - 一、大致介紹 1、本章節(jié)將 Zuul 的 regexmapper 屬性單獨(dú)拿出來,主要是這種配置規(guī)則,可以在一...
摘要:注意注解能注冊到服務(wù)上,是因?yàn)樵撟⒔獍丝蛻舳说淖⒔?,該是一個復(fù)合注解。地址可以查看該微服務(wù)網(wǎng)關(guān)代理了多少微服務(wù)的。 SpringCloud(第 020 篇)Zuul 網(wǎng)關(guān)模塊添加 listOfServers 屬性,達(dá)到客戶端負(fù)載均衡的能力 - 一、大致介紹 1、本章節(jié)添加另外一個屬性 listOfServers 來給 zuul 賦上異樣的功能色彩,提供負(fù)載均衡的能力; 2、而其實(shí)說...
閱讀 1877·2023-04-26 02:46
閱讀 2009·2021-11-25 09:43
閱讀 1150·2021-09-29 09:35
閱讀 2107·2019-08-30 15:56
閱讀 3431·2019-08-30 15:54
閱讀 2640·2019-08-29 16:35
閱讀 3127·2019-08-29 15:25
閱讀 3298·2019-08-29 14:01