日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Java RPC框架熔斷降級機制原理解析

瀏覽:207日期:2022-09-05 10:11:56

熔斷與降級

為什么在RPC環節中有熔斷以及降級的需求,詳細的原因這里不多解釋,從網上搜索一張圖做示意。

Java RPC框架熔斷降級機制原理解析

熔斷

我理解熔段主要解決如下幾個問題:

當所依賴的對象不穩定時,能夠起到快速失敗的目的快速失敗后,能夠根據一定的算法動態試探所依賴對象是否恢復

比如產品詳細頁獲取產品的好評總數時,由于后端服務異常導致客戶端每次都需要等到超時。如果短時間內服務不能恢復,那么這段時間內的所有請求時間都將是最大的超時時間,這類消費時間又得不到正確結果的現象是不能容忍的。所以遇到這類情況,就需要根據一定的算法判定服務短時間不可用,將后面的請求進行快速失敗處理,這樣可以節省服務等待時間。

同時,后端服務是有可能自主或者人為在一定時間內恢復的,所以之前被判定為快速失敗的服務,需要有能力去試探服務是否已經恢復。

上面提到的快速失敗以及自主恢復現象就是熔斷

降級

降級是指自己的待遇下降了,從RPC調用環節來講,就是去訪問一個本地的偽裝者而不是真實的服務,但這對調用端來說是沒有區別的。拿電商展示某個產品的詳細頁來說:

當加載評論時,由于評論服務不可用,此時可以返回一些默認的評論當加載產品庫存,由于庫存服務不可用,此時可以固定顯示一個庫存數

上面提供返回默認評論,固定庫存的服務就是偽裝服務,這類服務一般不依賴其它服務,穩定性最高。由偽裝者提供服務給客戶端的現象就是服務降級。

RPC如何支持熔斷與降級

一種最簡單的辦法就是借用hystrix來實現。

引入包依賴

由于示例未采用注解式方案,所以只需要引用下面兩個包即可。

<dependency> <groupId>com.netflix.hystrix</groupId> <artifactId>hystrix-core</artifactId> <version>${hystrix-version}</version></dependency><dependency> <groupId>com.netflix.hystrix</groupId> <artifactId>hystrix-metrics-event-stream</artifactId> <version>${hystrix-version}</version></dependency>

實現命令模式

hystrix遵循命令模式,這里可以往這個標準的UML圖上去套。

Java RPC框架熔斷降級機制原理解析

創建一個新的類,RpcHystrixCommand,繼承自HystrixCommand即可。

我這里采用線程隔離方式。

構造函數參數

由于需要遠程調用,所以構造函數需要接收遠程調用所需求必要參數

/** * 遠程目標方法 */private Method method;/** * 遠程目標接口 */private Object obj;/** * 遠程方法所需要的參數 */private Object[] params;/** * 遠程接口客戶端引用注解 */private RpcReference rpcReference;/** * RPC客戶端配置 */private ReferenceConfig referenceConfig;

構造函數方法簽名:

public RpcHystrixCommand(Object obj, Method method, Object[] params, RpcReference rpcReference, ReferenceConfig referenceConfig)

初始化hystrix

這里只是一個示例,所以參數設置比較隨意,詳細的可參考文檔。

super(Setter.withGroupKey(HystrixCommandGroupKey.Factory.asKey('CircuitBreakerRpcHystrixCommandGroup')) .andCommandKey(HystrixCommandKey.Factory.asKey('CircuitBreakerRpcHystrixCommandKey')) .andCommandPropertiesDefaults(HystrixCommandProperties.Setter() .withCircuitBreakerEnabled(true) .withCircuitBreakerRequestVolumeThreshold(1) .withCircuitBreakerErrorThresholdPercentage(50) .withCircuitBreakerSleepWindowInMilliseconds(5*1000) .withMetricsRollingStatisticalWindowInMilliseconds(10*1000) ) .andThreadPoolKey(HystrixThreadPoolKey.Factory.asKey('CircuitBreakerRpcHystrixCommandPool')) .andThreadPoolPropertiesDefaults(HystrixThreadPoolProperties.Setter().withCoreSize(100)) );

run()函數

run()函數就是正常調用時所需要執行的方法,將調用遠程通信的邏輯遷移到此,由于此處不涉及今天講的熔斷降級,所以不用關心里面的代碼。

@Overrideprotected Object run() { // 執行遠程調用}

擴展rpcReference注解以支持降級

在之前的注解中增加一個屬性,用來配置服務偽裝者所屬的類對象

public @interface RpcReference { /** * 服務降級的偽裝者類對象 * @return */ Class<?> fallbackServiceClazz() default Object.class;}

getFallback()函數

當快速失敗時,我們希望返回一些預先準備好的值給到客戶端,實現這個需求就需要實現這個fallback函數。

偽裝者的邏輯由于是客戶端控制,所以我們通過參數來動態支持。 通過rpcReference注解可以獲取配置的偽裝者

protected Object getFallback() { Method[] methods = this.rpcReference.fallbackServiceClazz().getMethods(); for (Method methodFallback : methods) { if(this.method.getName().equals(methodFallback.getName())){try { Object fallbackServiceMock= ApplicationContextUtils.getApplicationContext().getBean(this.rpcReference.fallbackServiceClazz()); return methodFallback.invoke(fallbackServiceMock,this.params);} catch (IllegalAccessException e) { logger.error('RpcHystrixCommand.getFallback error',e);} catch (InvocationTargetException e) { logger.error('RpcHystrixCommand.getFallback error',e);} } } throw new RpcException('service fallback unimplement'); }

RpcProxy嵌入熔斷降級機制

代理的invoke方法,將改調用命令模式的execute方法來代替。

@Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable { RpcHystrixCommand rpcHystrixCommand=new RpcHystrixCommand(proxy,method,args,this.reference,this.referenceConfig); return rpcHystrixCommand.execute();}

客戶端使用

dubbo有一個mock機制,功能有些弱,有興趣可以自行研究。我這里更加傾向于根據邏輯來判斷是否使用熔斷降級,降級的邏輯需要有更多的支持。

Spring Cloud的熔斷降級的做法與我的類似,它是通過注解在接口上

@FeignClient(value = 'JIM-CLOUD-PROVIDER-SERVER',fallback = ProductServiceHystrix.class)public interface ProductService { @RequestMapping(value = '/product/{productId}',method = RequestMethod.GET) String getById(@PathVariable('productId') final long productId);}

創建偽裝者接口

定義偽裝者接口,約定成員方法的簽名與真身相同。

public interface ProductCommentMockService { Product getById(Long productId);}

實現偽裝者接口

實現偽裝者接口,這里不光是簡單的固定數據,可心任意編寫偽裝者業務邏輯,與普通的service bean 沒有區別。

@Servicepublic class ProductCommentMockServiceImpl implements ProductCommentMockService { @Override public Product getById(Long productId) { Product mockProduct=new Product(); mockProduct.setId(0L); mockProduct.setName('mock product name'); return mockProduct; }}

服務引用使用熔斷降級機制

在引用遠程服務接口的注解上,配置偽裝者接口的類即可。

@RpcReference( maxExecutesCount = 1, fallbackServiceClazz = ProductCommentMockService.class)private ProductService productService;

測試

故意不啟動服務端,請求接口,此時出現mock數據說明組件功能正常。

{'id':0,'name':'mock product name'}

待解決問題

由于熔斷器采用的是新線程執行,所以會影響Rpc上下文傳遞的參數傳遞。

本文源碼

https://github.com/jiangmin168168/jim-framework

文中代碼是依賴上述項目的,如果有不明白的可下載源碼

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产亚洲人成a在线v网站| av资源新版天堂在线| 欧美日韩中文一区二区| 久久国产电影| 精品久久99| 99热精品在线| 91精品麻豆| 国产婷婷精品| 91精品蜜臀一区二区三区在线| 日韩一区二区三免费高清在线观看 | 久久精品国内一区二区三区水蜜桃| 91久久国产| 伊人久久在线| 麻豆91在线播放| 国产视频一区二区在线播放| 亚洲激精日韩激精欧美精品| 日本不卡一二三区黄网| 欧美日韩日本国产亚洲在线| av一区在线| 国产精品chinese| 国产日韩一区二区三区在线播放| 西西人体一区二区| 午夜久久免费观看| 久久精品高清| 久久97视频| 美女在线视频一区| 国产日韩一区二区三区在线| 亚洲最大av| 日韩一二三区在线观看| 四虎精品一区二区免费| 蜜桃久久精品一区二区| 精品国产免费人成网站| 首页国产精品| 国产91精品对白在线播放| 国产精品久久久久久久久久10秀 | 欧美日韩一区二区三区视频播放| 精品欧美一区二区三区在线观看| 久久精品亚洲| 国产在线看片免费视频在线观看| 四虎成人av| 久久天堂成人| 久久午夜影视| 久久精品99国产精品日本| 欧美a一区二区| 午夜精品成人av| 老色鬼精品视频在线观看播放| 国产人成精品一区二区三| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 亚洲国产专区校园欧美| 久久中文字幕二区| 日韩一区二区三区精品| 高清日韩中文字幕| 综合国产视频| 97国产精品| 日韩一区二区三区高清在线观看| 一区二区三区四区精品视频| 国产精品啊啊啊| 免费在线看一区| 午夜av不卡| 日韩精品免费观看视频| 日韩精品电影| 日韩av一区二区在线影视| 91精品韩国| 国产精品久久久久久久久久白浆| 国产一区精品福利| 婷婷精品在线| 米奇777超碰欧美日韩亚洲| 日本三级亚洲精品| 欧美成人久久| 福利视频一区| 久久高清免费| 精品国产一区二区三区av片| 香蕉成人久久| 极品日韩av| 99久精品视频在线观看视频| 欧美交a欧美精品喷水| 最新国产精品久久久| 亚洲综合精品| 午夜影院欧美| 黄色亚洲大片免费在线观看| 91精品一区二区三区综合| 日韩1区在线| 国产色噜噜噜91在线精品| 日韩欧美久久| 天堂网在线观看国产精品| 国产欧美日韩精品一区二区三区| 久久久夜精品| 国产一区二区三区四区| 国产精品亚洲综合在线观看| 欧美亚洲国产一区| 欧美日韩一区二区综合| 久久久久国产精品一区三寸| 老牛国内精品亚洲成av人片| 久久99久久久精品欧美| 日韩区一区二| 国内精品美女在线观看| 亚洲欧美网站| 日韩精品一级中文字幕精品视频免费观看 | 播放一区二区| 中文字幕成在线观看| 精品一区二区三区视频在线播放| 少妇高潮一区二区三区99| 亚洲欧美日韩视频二区| 国产精品丝袜xxxxxxx| 91精品成人| 狠狠久久婷婷| 蜜臀av亚洲一区中文字幕| 亚洲精华国产欧美| 黑丝一区二区三区| 亚洲欧美日韩国产一区二区| 亚洲精品一区二区妖精| 国产精品亚洲欧美一级在线| 久久国产精品免费一区二区三区 | 三级小说欧洲区亚洲区| 成人午夜亚洲| 婷婷成人在线| 欧美日韩中文一区二区| 99在线|亚洲一区二区| 性一交一乱一区二区洋洋av| 国产精品7m凸凹视频分类| 亚州av乱码久久精品蜜桃| 亚洲精品无播放器在线播放| 一区二区91| 久久精品一区| 日韩高清中文字幕一区| 蜜桃一区二区三区在线| 91精品丝袜国产高跟在线| 精品日产乱码久久久久久仙踪林| 精品视频91| 丝袜亚洲另类欧美| 欧美成人精品午夜一区二区| 999久久久国产精品| 欧美中文字幕| 欧美久久亚洲| 国产婷婷精品| 成人在线视频区| 亚洲一二av| 日本在线啊啊| 久久精品 人人爱| 一二三区精品| 欧美激情五月| 亚洲一区二区日韩| 国产伦理久久久久久妇女| 偷拍欧美精品| 欧美日韩国产观看视频| 国产一级成人av| 麻豆9191精品国产| 亚洲成人三区| 日韩影院二区| 九九久久国产| 亚洲精品综合| 国产精品毛片在线看| 久久久久久美女精品| 美腿丝袜亚洲一区| 欧美在线亚洲| 日韩欧美视频专区| 精品色999| 久久国产欧美日韩精品| 99久久久久| 视频一区日韩精品| 亚洲精品一级| 视频一区日韩| 激情综合自拍| 亚洲www啪成人一区二区| 欧美日韩四区| 免费视频亚洲| 激情91久久| 日韩一区二区免费看| 久久中文字幕av| 日韩1区2区3区| 国产欧美三级| 精品久久免费| 欧美不卡在线| 中文字幕成人| 另类专区亚洲| 国产综合色区在线观看| 欧美日本一区| 国产精品成人自拍| 成人日韩在线观看| 亚洲精品va| 婷婷五月色综合香五月| 女主播福利一区| 日韩视频精品在线观看| 不卡中文一二三区| 久久国产成人午夜av影院宅| 午夜一级久久| 麻豆久久久久久久| 午夜久久中文| 免费日韩视频| 国产日韩亚洲| 日本不卡一二三区黄网| 福利一区二区免费视频| 亚洲视频国产精品| 中文在线а√天堂| 婷婷五月色综合香五月| 欧美中文一区二区| 麻豆精品蜜桃视频网站| 日韩成人高清| 成人午夜网址| 国产福利一区二区三区在线播放|