国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

使用SpringBoot實現微服務超時重試模式的示例

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

使用resilience4j的庫和Spring Boot設計高彈性的微服務。

微服務本質上是分布式的。當您使用分布式系統時,請始終記住這一第一法則- 網絡中可能發生任何事情。處理任何此類意外故障可能很難解決。故障可能是任何東西-應用程序,硬件或網絡等。

系統從故障中恢復并保持正常運行的能力使系統更具 彈性。它還避免了下游服務的任何級聯故障。

重試模式:

在微服務體系結構中,當有多個服務(A,B,C和D)時,一個服務(A)可能依賴于另一服務(B),而另一服務(B)又可能依賴于C,依此類推。有時由于某些問題,服務D可能無法按預期響應。服務D可能引發了某些異常,例如內存不足 錯誤或內部服務器錯誤。此類異常被級聯到下游服務,這可能導致不良的用戶體驗,如下所示。

使用SpringBoot實現微服務超時重試模式的示例

有時,當google.com對我們不起作用時,我們只是不放棄。我們假設頁面下次可以正常工作,并且大多數情況下都會刷新頁面,因此只需刷新頁面即可。間歇性網絡問題非常普遍。在微服務領域,我們可能正在運行同一服務D的多個實例,以實現高可用性和負載平衡。如果其中一個實例可能有問題,并且無法正確響應我們的請求,則如果我們重試該請求,則負載均衡器可以將請求發送到運行狀況良好的節點并正確獲得響應。因此,使用“重試”選項,我們有更多機會獲得正確的響應。

使用SpringBoot實現微服務超時重試模式的示例

讓我們考慮這個簡單的應用程序來解釋此重試模式。

使用SpringBoot實現微服務超時重試模式的示例

如上所述,我們有多個微服務 產品服務充當產品目錄并負責提供產品信息 產品服務取決于評級服務。 評分服務維護產品評論和評分。 由于擁有大量數據而速度慢是眾所周知的。 每當我們查看產品詳細信息時,產品服務就會將請求發送到評分服務,以獲取該產品的評論。 我們還有其他服務,例如帳戶服務,訂單服務和付款服務等,與本文的討論無關。 產品服務是一項核心服務,沒有它,用戶將無法啟動訂單工作流程。

設置:

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

產品服務負責根據用戶搜索條件提供產品列表。它是即使在關鍵負載下也應該啟動和響應的核心服務之一。如果下降,將嚴重影響收入。由于此服務取決于評級服務,因此我們不希望任何網絡問題或評級服務不可用性影響此產品服務。這就是使用 resilience4j 庫的目的。

我首先為resilience4j創建一個配置, 如下所示。在這里,我們將超時明確設置為3秒。我們可以在特定的超時時間內添加多個服務。 我們可以有多種服務配置,如下所示。 對于ratingService,我們將最多進行3次重試,延遲5秒。 retryExceptions:這些是我們將重試的異常。這是一個數組字段。您可以配置多個例外。 ignoreExceptions:有些異常我們可能不想重試。例如,一個錯誤的請求就是一個錯誤的請求。重試沒有意義。因此,我們忽略了這一點。

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將對該方法執行應用重試邏輯。 name = ratingService 表示 resilience4j 將使用yaml中的ratingService配置。 當main方法由于某種原因失敗時,將使用fallbackMethod。

總結

重試模式 是用于設計彈性微服務的最簡單的微服務 設計模式之一。引入重試可以解決與網絡相關的問題。

源代碼可 在此處獲得。

超時模式源碼可在此處獲得。

以上就是使用SpringBoot實現微服務超時重試模式的示例的詳細內容,更多關于SpringBoot實現微服務超時的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
主站蜘蛛池模板: 天堂素人搭讪系列嫩模在线观看 | 美女18一级毛片免费看 | 国产三级日本三级日产三级66 | 国产精品色内内在线播放 | yellow中文字幕久久网 | 欧美一级成人一区二区三区 | 黄网站色视频免费观看w | 91b站 | 久久精品国产一区 | 99re这里只有精品99 | 在线精品免费视频 | 毛片免费观看的视频 | 欧美成人精品一区二区三区 | 成人久久18免费网站入口 | 亚洲精品国产拍拍拍拍拍 | 综合 欧美 国产 视频二区 | 爱啪网亚洲第一福利网站 | 亚洲午夜精品一级在线 | 国产欧美日韩精品在线 | 国产精品亚洲专区在线播放 | 国产亚洲免费观看 | 亚洲综合色一区二区三区小说 | 亚洲成人高清在线 | 亚洲精品一二三四区 | 在线一区播放 | 成人在线网站 | 中文字幕亚洲在线 | 久久国产经典视频 | 久草免费资源 | 99热久久国产综合精品久久国产 | 成人在线免费视频 | 国产精品天天爽夜夜欢张柏芝 | 亚洲高清中文字幕一区二区三区 | 国产精品久久久久影院 | 国产亚洲精品久久久久91网站 | 国产欧美成人xxx视频 | 中文字幕亚洲一区二区v@在线 | 日韩欧美一中字暮 | 免费看成人播放毛片 | 91精品国产91久久 | 国产在线观看第一页 |