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