真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

詳解springcloud分布式關(guān)于熔斷器

spring cloud分布式中,熔斷器就是斷路器,其實(shí)都是一個意思。

創(chuàng)新互聯(lián)于2013年成立,先為富寧等服務(wù)建站,富寧等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為富寧企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

為什么要使用熔斷器呢?

在分布式中,我們會根據(jù)業(yè)務(wù)或功能將項目拆分為多個服務(wù)單元,各個服務(wù)單元之間通過服務(wù)注冊和訂閱的方式相互依賴和調(diào)用功能,隨著項目和業(yè)務(wù)的不斷拓展,服務(wù)單元數(shù)量也逐漸增多,相互之間的依賴關(guān)系也越來越復(fù)雜,這時候,可能會某個服務(wù)單元出現(xiàn)問題或網(wǎng)絡(luò)原因依賴調(diào)用出錯或延遲,此時如果調(diào)用該依賴的請求不斷增加,那么要調(diào)用該服務(wù)的服務(wù)將都會等待或者出現(xiàn)故障,如果后續(xù)連鎖反應(yīng)越來越多,Servlet容器的線程資源會被消耗完畢,導(dǎo)致服務(wù)癱瘓。服務(wù)與服務(wù)的依賴會導(dǎo)致服務(wù)之間的故障傳播,從而迎來“雪崩效應(yīng)“。為了解決這種每個點(diǎn)或多個點(diǎn)的故障,就有了熔斷器的出現(xiàn)。

什么是熔斷器?

熔斷器就相當(dāng)于電路中的保險絲、保護(hù)器,它可以實(shí)現(xiàn)快速失敗,如果它在某一段時間里偵測到許多類似的錯誤,它將不再訪問遠(yuǎn)程服務(wù)器,會強(qiáng)迫以后的訪問都會快速失敗,從而防止某個服務(wù)不斷地嘗試執(zhí)行可能會失敗的操作,它會使服務(wù)繼續(xù)執(zhí)行而不用等待修正錯誤,或者浪費(fèi)CPU時間去等到長時間的超時產(chǎn)生,從而進(jìn)入回路方法。熔斷器也可以使服務(wù)能夠診斷錯誤是否已經(jīng)修正,如果已經(jīng)修正,服務(wù)會再次嘗試調(diào)用操作。

詳解spring cloud分布式關(guān)于熔斷器

1.在調(diào)用服務(wù)方加入熔斷器依賴jar包:

 // https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-hystrix
  compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix'

2.在Controller中:

@Controller
//@EnableWebSecurity 安全檢查controller還要繼承extends WebSecurityConfigurerAdapter
public class PageController  {

  public static Logger logger=LoggerFactory.getLogger(PageController.class);

  @Autowired
  private RestTemplate restTemplate;


  @HystrixCommand(fallbackMethod = "toIndex1")//斷路器進(jìn)入回路方法
  @RequestMapping("/toIndex1")
  public String toIndex(Model model){

    System.out.println("進(jìn)入toIndex");
    logger.info("執(zhí)行調(diào)用");
    String msg=restTemplate.getForEntity("http://project-solr/SolrSearch",String.class).getBody();//project-solr是調(diào)用注冊中心里的名字
    logger.info("調(diào)用結(jié)束");
    model.addAttribute("msg",msg);
    return "index";
  }

  public String toIndex1(Model model){
    System.out.println("進(jìn)入回路方法");
    model.addAttribute("msg","服務(wù)不可用,請稍后重試");
    return "index";
  }
}

注意:在調(diào)用方服務(wù)Controller中的方法上加上@HystrixCommand(fallbackMethod = "回路方法")

這里我讓回路方法調(diào)用的是toIndex1,要注意回路方法返回值,參數(shù)要與原方法一致

在被調(diào)用方的方法中制造故障:

詳解spring cloud分布式關(guān)于熔斷器

3.在調(diào)用方的啟動類加注解@EnableCircuitBreaker啟動熔斷器

啟動:

詳解spring cloud分布式關(guān)于熔斷器

詳解spring cloud分布式關(guān)于熔斷器

可以看到進(jìn)入了回路方法

當(dāng)然還可以在調(diào)用方進(jìn)行配置:

hystrix:
 command:
  default:
   execution:
   isolation:
    thread:
     timeoutInMilliseconds: 2000 #請求響應(yīng)時間 如果過了這個時間就會進(jìn)入回路方法
   circuitBreaker:
     requestVolumeThreshold: 2 # 服務(wù)降級:此請求連續(xù)多少次響應(yīng)過慢或崩潰 系統(tǒng)就默認(rèn)把它當(dāng)成一個崩潰的方法 在一定時間內(nèi)調(diào)用此方法會直接進(jìn)入回路方法 這樣執(zhí)行更快 默認(rèn)值是20 請求該方法20次 如果崩潰或響應(yīng)過慢率大于百分之八十 就會默認(rèn)它是一個崩潰方法 
      #timeout:
        #enabled: false #取消超時檢查 無論線程運(yùn)行多久 只要不崩潰就不進(jìn)入回路方法 一般情況不使用

配置完后運(yùn)行:

詳解spring cloud分布式關(guān)于熔斷器

運(yùn)行好幾次發(fā)現(xiàn)它會前兩次會訪問并等待相應(yīng)結(jié)果,后面不再訪問就直接回應(yīng)結(jié)果進(jìn)入回路方法

當(dāng)然這是根據(jù)配置:

詳解spring cloud分布式關(guān)于熔斷器

spring cloud熔斷器就說到這里,想了解spring cloud其他內(nèi)容,請瀏覽我以前博客

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


本文標(biāo)題:詳解springcloud分布式關(guān)于熔斷器
當(dāng)前地址:http://weahome.cn/article/gopgji.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部