javascript
resttemplate 请求重试_使用Spring Cloud Ribbon重试请求
使用Spring Cloud Ribbon重試請求
在微服務(wù)調(diào)用中,一些微服務(wù)圈可能調(diào)用失敗,通過再次調(diào)用以達到系統(tǒng)穩(wěn)定性效果,本文展示如何使用Ribbon和Spring Retry進行請求再次重試調(diào)用。
在Spring Cloud中,使用load balanced?RestTemplate對外部服務(wù)進行請求調(diào)用,創(chuàng)建一個負載平衡的RestTemplate是非常簡單:
@Configuration
public class MyConfiguration {
@LoadBalanced
@Bean
RestTemplate restTemplate() {
return new RestTemplate();
}
}
public class MyClass {
@Autowired
private RestTemplate restTemplate;
public String doOtherStuff() {
String results = restTemplate.getForObject("http://stores/stores", String.class);
return results;
}
}
這里加入@LoadBalanced?元注解讓你利用一個發(fā)現(xiàn)服務(wù)比如Eureka進行服務(wù)注冊,正如你在doOtherStuff方法中看到,我們對URL http://stores/stores發(fā)出請求,主機名stores并不是實際注冊的主機名,而是在發(fā)現(xiàn)服務(wù)器中注冊的stroes服務(wù)名稱,RestTemplate將使用stores服務(wù)所在主機名或IP地址替代stores主機名。
正如我們都知道,這樣的請求可能有問題。 出于任何原因,某些可能會出錯,請求可能會失敗。 這就是為什么在健壯的應(yīng)用程序中,當(dāng)遇到失敗時,可以重試類似上面的API請求。 發(fā)生這種失敗問題原因可能是服務(wù)完全停止,我們永遠不會得到回應(yīng)。 然而,故障可能的是由于某種類型的網(wǎng)絡(luò)問題,并且隨后的請求可能會成功。 甚至可能是服務(wù)的某個特定實例可能遇到問題的情況,但是存在完全可能是請求另一實例時卻能夠處理。
在Spring Cloud,如果你使用一個負載平衡RESTTemplate進行API請求,如果請求失敗,開發(fā)者可以決定重試請求,在?Spring Retry project?項目中提供重試邏輯,使用?Ribbon properties?配置重試次數(shù)以及哪個請求需要重試。
總結(jié)
以上是生活随笔為你收集整理的resttemplate 请求重试_使用Spring Cloud Ribbon重试请求的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: golang插入字符串_golang 几
- 下一篇: gradle idea java ssm