电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

使用SpringBoot實(shí)現(xiàn)微服務(wù)超時(shí)重試模式的示例

瀏覽:3日期:2023-04-09 17:58:29

使用resilience4j的庫和Spring Boot設(shè)計(jì)高彈性的微服務(wù)。

微服務(wù)本質(zhì)上是分布式的。當(dāng)您使用分布式系統(tǒng)時(shí),請(qǐng)始終記住這一第一法則- 網(wǎng)絡(luò)中可能發(fā)生任何事情。處理任何此類意外故障可能很難解決。故障可能是任何東西-應(yīng)用程序,硬件或網(wǎng)絡(luò)等。

系統(tǒng)從故障中恢復(fù)并保持正常運(yùn)行的能力使系統(tǒng)更具 彈性。它還避免了下游服務(wù)的任何級(jí)聯(lián)故障。

重試模式:

在微服務(wù)體系結(jié)構(gòu)中,當(dāng)有多個(gè)服務(wù)(A,B,C和D)時(shí),一個(gè)服務(wù)(A)可能依賴于另一服務(wù)(B),而另一服務(wù)(B)又可能依賴于C,依此類推。有時(shí)由于某些問題,服務(wù)D可能無法按預(yù)期響應(yīng)。服務(wù)D可能引發(fā)了某些異常,例如內(nèi)存不足 錯(cuò)誤或內(nèi)部服務(wù)器錯(cuò)誤。此類異常被級(jí)聯(lián)到下游服務(wù),這可能導(dǎo)致不良的用戶體驗(yàn),如下所示。

使用SpringBoot實(shí)現(xiàn)微服務(wù)超時(shí)重試模式的示例

有時(shí),當(dāng)google.com對(duì)我們不起作用時(shí),我們只是不放棄。我們假設(shè)頁面下次可以正常工作,并且大多數(shù)情況下都會(huì)刷新頁面,因此只需刷新頁面即可。間歇性網(wǎng)絡(luò)問題非常普遍。在微服務(wù)領(lǐng)域,我們可能正在運(yùn)行同一服務(wù)D的多個(gè)實(shí)例,以實(shí)現(xiàn)高可用性和負(fù)載平衡。如果其中一個(gè)實(shí)例可能有問題,并且無法正確響應(yīng)我們的請(qǐng)求,則如果我們重試該請(qǐng)求,則負(fù)載均衡器可以將請(qǐng)求發(fā)送到運(yùn)行狀況良好的節(jié)點(diǎn)并正確獲得響應(yīng)。因此,使用“重試”選項(xiàng),我們有更多機(jī)會(huì)獲得正確的響應(yīng)。

使用SpringBoot實(shí)現(xiàn)微服務(wù)超時(shí)重試模式的示例

讓我們考慮這個(gè)簡(jiǎn)單的應(yīng)用程序來解釋此重試模式。

使用SpringBoot實(shí)現(xiàn)微服務(wù)超時(shí)重試模式的示例

如上所述,我們有多個(gè)微服務(wù) 產(chǎn)品服務(wù)充當(dāng)產(chǎn)品目錄并負(fù)責(zé)提供產(chǎn)品信息 產(chǎn)品服務(wù)取決于評(píng)級(jí)服務(wù)。 評(píng)分服務(wù)維護(hù)產(chǎn)品評(píng)論和評(píng)分。 由于擁有大量數(shù)據(jù)而速度慢是眾所周知的。 每當(dāng)我們查看產(chǎn)品詳細(xì)信息時(shí),產(chǎn)品服務(wù)就會(huì)將請(qǐng)求發(fā)送到評(píng)分服務(wù),以獲取該產(chǎn)品的評(píng)論。 我們還有其他服務(wù),例如帳戶服務(wù),訂單服務(wù)和付款服務(wù)等,與本文的討論無關(guān)。 產(chǎn)品服務(wù)是一項(xiàng)核心服務(wù),沒有它,用戶將無法啟動(dòng)訂單工作流程。

設(shè)置:

<dependency> <groupId>io.github.resilience4j</groupId> <artifactId>resilience4j-spring-boot2</artifactId> <version>1.6.1</version></dependency>

產(chǎn)品服務(wù)負(fù)責(zé)根據(jù)用戶搜索條件提供產(chǎn)品列表。它是即使在關(guān)鍵負(fù)載下也應(yīng)該啟動(dòng)和響應(yīng)的核心服務(wù)之一。如果下降,將嚴(yán)重影響收入。由于此服務(wù)取決于評(píng)級(jí)服務(wù),因此我們不希望任何網(wǎng)絡(luò)問題或評(píng)級(jí)服務(wù)不可用性影響此產(chǎn)品服務(wù)。這就是使用 resilience4j 庫的目的。

我首先為resilience4j創(chuàng)建一個(gè)配置, 如下所示。在這里,我們將超時(shí)明確設(shè)置為3秒。我們可以在特定的超時(shí)時(shí)間內(nèi)添加多個(gè)服務(wù)。 我們可以有多種服務(wù)配置,如下所示。 對(duì)于ratingService,我們將最多進(jìn)行3次重試,延遲5秒。 retryExceptions:這些是我們將重試的異常。這是一個(gè)數(shù)組字段。您可以配置多個(gè)例外。 ignoreExceptions:有些異常我們可能不想重試。例如,一個(gè)錯(cuò)誤的請(qǐng)求就是一個(gè)錯(cuò)誤的請(qǐng)求。重試沒有意義。因此,我們忽略了這一點(diǎn)。

resilience4j.retry: instances: ratingService: maxRetryAttempts: 3 waitDuration: 5s retryExceptions:- org.springframework.web.client.HttpServerErrorException ignoreExceptions:- org.springframework.web.client.HttpClientErrorException someOtherService: maxRetryAttempts: 3 waitDuration: 10s retryExceptions:- org.springframework.web.client.HttpServerErrorException- java.io.IOException

代碼:

@Servicepublic class RatingServiceClient { private final RestTemplate restTemplate = new RestTemplate(); @Value('${rating.service.endpoint}') private String ratingService; @Retry(name = 'ratingService', fallbackMethod = 'getDefault') public CompletionStage<ProductRatingDto> getProductRatingDto(int productId){Supplier<ProductRatingDto> supplier = () -> this.restTemplate.getForEntity(this.ratingService + productId, ProductRatingDto.class) .getBody();return CompletableFuture.supplyAsync(supplier); } private CompletionStage<ProductRatingDto> getDefault(int productId, HttpClientErrorException throwable){return CompletableFuture.supplyAsync(() -> ProductRatingDto.of(0, Collections.emptyList())); }}

代碼解釋:

@Retry表示resilience4j將對(duì)該方法執(zhí)行應(yīng)用重試邏輯。 name = ratingService 表示 resilience4j 將使用yaml中的ratingService配置。 當(dāng)main方法由于某種原因失敗時(shí),將使用fallbackMethod。

總結(jié)

重試模式 是用于設(shè)計(jì)彈性微服務(wù)的最簡(jiǎn)單的微服務(wù) 設(shè)計(jì)模式之一。引入重試可以解決與網(wǎng)絡(luò)相關(guān)的問題。

源代碼可 在此處獲得。

超時(shí)模式源碼可在此處獲得。

以上就是使用SpringBoot實(shí)現(xiàn)微服務(wù)超時(shí)重試模式的示例的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot實(shí)現(xiàn)微服務(wù)超時(shí)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 湖南印刷厂|长沙印刷公司|画册印刷|挂历印刷|台历印刷|杂志印刷-乐成印刷 | 专业广州网站建设,微信小程序开发,一物一码和NFC应用开发、物联网、外贸商城、定制系统和APP开发【致茂网络】 | 交联度测试仪-湿漏电流测试仪-双85恒温恒湿试验箱-常州市科迈实验仪器有限公司 | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | 接地电阻测试仪[厂家直销]_电缆故障测试仪[精准定位]_耐压测试仪-武汉南电至诚电力设备 | 合景一建-无尘车间设计施工_食品医药洁净车间工程装修总承包公司 | 一氧化氮泄露报警器,二甲苯浓度超标报警器-郑州汇瑞埔电子技术有限公司 | 皮带机-带式输送机价格-固定式胶带机生产厂家-河南坤威机械 | 塑料熔指仪-塑料熔融指数仪-熔体流动速率试验机-广东宏拓仪器科技有限公司 | 注浆压力变送器-高温熔体传感器-矿用压力传感器|ZHYQ朝辉 | 磁棒电感生产厂家-电感器厂家-电感定制-贴片功率电感供应商-棒形电感生产厂家-苏州谷景电子有限公司 | 防弹玻璃厂家_防爆炸玻璃_电磁屏蔽玻璃-四川大硅特玻科技有限公司 | 合肥抖音SEO网站优化-网站建设-网络推广营销公司-百度爱采购-安徽企匠科技 | 水冷散热器_水冷电子散热器_大功率散热器_水冷板散热器厂家-河源市恒光辉散热器有限公司 | 密集架-手摇-智能-移动-价格_内蒙古档案密集架生产厂家 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 水平垂直燃烧试验仪-灼热丝试验仪-漏电起痕试验仪-针焰试验仪-塑料材料燃烧检测设备-IP防水试验机 | 北钻固控设备|石油钻采设备-石油固控设备厂家 | 衬塑管道_衬四氟管道厂家-淄博恒固化工设备有限公司 | 钢格板_钢格栅_格栅板_钢格栅板 - 安平县鑫拓钢格栅板厂家 | 北京开源多邦科技发展有限公司官网 | 单柱拉力机-橡胶冲片机-哑铃裁刀-江都轩宇试验机械厂 | 新疆十佳旅行社_新疆旅游报价_新疆自驾跟团游-新疆中西部国际旅行社 | HDPE储罐_厂家-山东九州阿丽贝防腐设备 | 贵阳用友软件,贵州财务软件,贵阳ERP软件_贵州优智信息技术有限公司 | 电加热导热油炉-空气加热器-导热油加热器-翅片电加热管-科安达机械 | 首页_欧瑞传动官方网站--主营变频器、伺服系统、新能源、软起动器、PLC、HMI | 阿尔法-MDR2000无转子硫化仪-STM566 SATRA拉力试验机-青岛阿尔法仪器有限公司 | 并离网逆变器_高频UPS电源定制_户用储能光伏逆变器厂家-深圳市索克新能源 | 双齿辊破碎机-大型狼牙破碎机视频-对辊破碎机价格/型号图片-金联机械设备生产厂家 | BESWICK球阀,BESWICK接头,BURKERT膜片阀,美国SEL继电器-东莞市广联自动化科技有限公司 | 云南丰泰挖掘机修理厂-挖掘机维修,翻新,再制造的大型企业-云南丰泰工程机械维修有限公司 | 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 威客电竞(vk·game)·电子竞技赛事官网 | 隐形纱窗|防护纱窗|金刚网防盗纱窗|韦柏纱窗|上海青木装潢制品有限公司|纱窗国标起草单位 | 物流之家新闻网-最新物流新闻|物流资讯|物流政策|物流网-匡匡奈斯物流科技 | 粉丝机械,粉丝烘干机,粉丝生产线-招远市远东粉丝机械有限公司 | 优考试_免费在线考试系统_培训考试系统_题库系统_组卷答题系统_匡优考试 | 纸张环压仪-纸张平滑度仪-杭州纸邦自动化技术有限公司 | 便携式谷丙转氨酶检测仪|华图生物科技百科 | 智成电子深圳tdk一级代理-提供TDK电容电感贴片蜂鸣器磁芯lambda电源代理经销,TDK代理商有哪些TDK一级代理商排名查询。-深圳tdk一级代理 |