亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

spring-cloud-gateway降級(jí)的實(shí)現(xiàn)

瀏覽:94日期:2023-09-12 14:44:20

前言

本文主要研究一下 spring cloud gateway 如何集成 hystrix。

當(dāng)下游接口負(fù)載很大,或者接口不通等其他原因?qū)е鲁瑫r(shí),如果接口不熔斷的話將會(huì)影響到下游接口得不到喘息,網(wǎng)關(guān)也會(huì)因?yàn)槌瑫r(shí)連接一直掛起,很可能因?yàn)橐粋€(gè)子系統(tǒng)的問(wèn)題導(dǎo)致整個(gè)系統(tǒng)的雪崩。所以我們的網(wǎng)關(guān)需要設(shè)計(jì)熔斷,當(dāng)因?yàn)槿蹟嗥鞔蜷_(kāi)時(shí),網(wǎng)關(guān)將返回一個(gè)降級(jí)的應(yīng)答。

Maven 配置

添加 hystrix 依賴

pom.xml

<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> </dependency>

項(xiàng)目實(shí)戰(zhàn)

在 provider1 服務(wù)中添加一個(gè)方法,延時(shí) 2 秒返回響應(yīng)。

@GetMapping('/timeout') public String timeout() { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println('休眠了2秒'); return 'timeout test'; }

修改網(wǎng)關(guān)配置文件

server: port: 2000spring: application: name: idc-gateway2 redis: host: localhost port: 6379 timeout: 6000ms # 連接超時(shí)時(shí)長(zhǎng)(毫秒) jedis: pool: max-active: 1000 # 連接池最大連接數(shù)(使用負(fù)值表示沒(méi)有限制) max-wait: -1ms # 連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒(méi)有限制) max-idle: 10 # 連接池中的最大空閑連接 min-idle: 5 # 連接池中的最小空閑連接 cloud: consul: host: localhost port: 8500 gateway: discovery: locator: enabled: true # gateway可以通過(guò)開(kāi)啟以下配置來(lái)打開(kāi)根據(jù)服務(wù)的serviceId來(lái)匹配路由,默認(rèn)是大寫(xiě) routes: - id: provider1 uri: lb://idc-provider1 predicates: - Path=/p1/** filters: - StripPrefix=1 - name: Hystrix args:name: defaultfallbackUri: forward:/defaultfallback # 只有該id下的服務(wù)會(huì)降級(jí) - id: provider2 uri: lb://idc-provider2 predicates: - Path=/p2/** filters: - StripPrefix=1# hystrix 信號(hào)量隔離,1.5秒后自動(dòng)超時(shí)hystrix: command: default: execution: isolation: strategy: SEMAPHORE thread: timeoutInMilliseconds: 1500

網(wǎng)關(guān)添加降級(jí)處理類

@RestControllerpublic class FallbackController {@RequestMapping('/defaultfallback')public Map<String,Object> defaultfallback(){System.out.println('降級(jí)操作...');Map<String,Object> map = new HashMap<>();map.put('code',200);map.put('msg','服務(wù)超時(shí)降級(jí)');map.put('data',null);return map;}}

降級(jí)測(cè)試

超時(shí)服務(wù)降級(jí)

curl http://localhost:2000/p1/timeout

返回

{'msg':'服務(wù)超時(shí)降級(jí)','code':200,'data':null}

其他異常

spring-cloud-gateway 調(diào)用下游服務(wù)返回的異常,網(wǎng)關(guān)不做任何處理,會(huì)直接返回。大家想一下為什么在網(wǎng)關(guān)不去處理下游異常呢? 因?yàn)楹芏鄷r(shí)候下游的異常是包含有效信息的(異常信息千千萬(wàn)),如果在網(wǎng)關(guān)處做了統(tǒng)一返回,就失去了返回異常的意義。

spring-cloud-starter-netflix-hystrix 內(nèi)置的 Hystrix 過(guò)濾器是HystrixGatewayFilterFactory。 感興趣的小伙伴可以自行閱讀相關(guān)源碼。

到此這篇關(guān)于spring-cloud-gateway降級(jí)的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)spring-cloud-gateway降級(jí) 內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 亚洲天堂色视频 | 91短视频版在线观看免费大全 | 看免费毛片 | 青青青视频免费一区二区 | 国产www| 国产成人高清在线观看播放 | 青青自拍视频一区二区三区 | 2048国产精品原创综合在线 | 成人性生活视频 | 久久香蕉国产 | 免费的黄色小视频 | 久久精品成人欧美大片免费 | 国产a级淫片 | 日本乱理伦中文三区 | 亚洲国产欧美国产第一区二区三区 | 久久国产这里只精品免费 | 亚洲午夜精品一区二区 | 中文一级国产特级毛片视频 | 成人中文字幕在线高清 | 99久久国产免费福利 | 手机看片福利日韩国产 | 黄色激情网址 | 欧美一区二区三区免费高 | 国产精品亚洲精品日韩已满 | 免费污片在线观看 | 极品销魂一区二区三区 | 亚洲精品第一综合99久久 | 一级黄色大片网站 | 一级黄网 | 亚洲乱码一二三四区国产 | 久久一本一区二区三区 | japenese色系tube日本护士 | aaa一级片 | 亚色一区 | 毛片网站在线观看 | 青青草原综合久久大伊人精品 | 欧美精品人爱c欧美精品 | 一级啊片 | 亚洲精品久久一区影院 | 小泽玛利亚在线精品一区二区 | 国产在线观看第一页 |