深入理解 Ribbon-Hystrix-Feign 三者之間的關(guān)系(一)

因?yàn)樵诠咀罱捻?xiàng)目中,使用的架構(gòu)是spring-cloud的微服務(wù)架構(gòu)玫荣,然后正好公司組織了一次關(guān)于spring-cloud的相關(guān)的一些技術(shù)分享甚淡,故在此處將對(duì)于spring-cloud 中對(duì)于ribbon ,hystrix 和 feign的作用和關(guān)系做一個(gè)學(xué)習(xí)記錄捅厂,以方便以后查看贯卦。

Ribbon介紹


Ribbon是Netflix發(fā)布的開(kāi)源項(xiàng)目底挫,主要功能是提供客戶端的軟件負(fù)載均衡算法,將Netflix的中間層服務(wù)連接在一起脸侥。Ribbon客戶端組件提供一系列完善的配置項(xiàng)如連接超時(shí)建邓,重試等。簡(jiǎn)單的說(shuō)睁枕,就是在配置文件中列出Load Balancer后面所有的機(jī)器官边,Ribbon會(huì)自動(dòng)的幫助你基于某種規(guī)則(如簡(jiǎn)單輪詢,隨機(jī)連接等)去連接這些機(jī)器外遇。我們也很容易使用Ribbon實(shí)現(xiàn)自定義的負(fù)載均衡算法注簿。簡(jiǎn)單地說(shuō),Ribbon是一個(gè)客戶端負(fù)載均衡器跳仿。

Ribbon工作時(shí)分為兩步:第一步先選擇 Eureka Server, 它優(yōu)先選擇在同一個(gè)Zone且負(fù)載較少的Server诡渴;第二步再根據(jù)用戶指定的策略,在從Server取到的服務(wù)注冊(cè)列表中選擇一個(gè)地址菲语。其中Ribbon提供了多種策略妄辩,例如輪詢、隨機(jī)山上、根據(jù)響應(yīng)時(shí)間加權(quán)等眼耀。

ribbon源碼的github地址:

https://github.com/Netflix/ribbon

Feign介紹


Feign是一個(gè)聲明式的web service客戶端,它使得編寫(xiě)web service客戶端更為容易佩憾。創(chuàng)建接口哮伟,為接口添加注解,即可使用Feign妄帘。Feign可以使用Feign注解或者JAX-RS注解楞黄,還支持熱插拔的編碼器和解碼器。Spring Cloud為Feign添加了Spring MVC的注解支持抡驼,并整合了Ribbon和Eureka來(lái)為使用Feign時(shí)提供負(fù)載均衡鬼廓。

feign源碼的github地址:

https://github.com/OpenFeign/feign

Hystrix介紹


Hystrix熔斷器,容錯(cuò)管理工具婶恼,旨在通過(guò)熔斷機(jī)制控制服務(wù)和第三方庫(kù)的節(jié)點(diǎn),從而對(duì)延遲和故障提供更強(qiáng)大的容錯(cuò)能力桑阶。在Spring Cloud Hystrix中實(shí)現(xiàn)了線程隔離、斷路器等一系列的服務(wù)保護(hù)功能勾邦。它也是基于Netflix的開(kāi)源框架 Hystrix實(shí)現(xiàn)的,該框架目標(biāo)在于通過(guò)控制那些訪問(wèn)遠(yuǎn)程系統(tǒng)割择、服務(wù)和第三方庫(kù)的節(jié)點(diǎn)眷篇,從而對(duì)延遲和故障提供更強(qiáng)大的容錯(cuò)能力。Hystrix具備了服務(wù)降級(jí)荔泳、服務(wù)熔斷蕉饼、線程隔離虐杯、請(qǐng)求緩存、請(qǐng)求合并以及服務(wù)監(jiān)控等強(qiáng)大功能昧港。

Hystrix源碼的github地址:

https://github.com/Netflix/hystrix

下面我們就來(lái)看一下在微服務(wù)中擎椰,如何快速的使用它們

在一個(gè)請(qǐng)求進(jìn)入到我們系統(tǒng)之后,我們的系統(tǒng)具體是怎么的一個(gè)流程來(lái)處理的呢创肥?可能每個(gè)同學(xué)都有自己的理解达舒,下面我畫(huà)了一個(gè)圖來(lái)比較形象的描述我對(duì)于這些組件之間的關(guān)系的一個(gè)圖,有不對(duì)的地方叹侄,請(qǐng)大家批評(píng)指正:


具體使用


代碼實(shí)現(xiàn)示例

1.工程目錄結(jié)構(gòu)

本次我們準(zhǔn)備了4個(gè)工程模塊巩搏,分別是:

a.基于spring-boot的服務(wù)提供模塊:service-demo

b.基于eureka實(shí)現(xiàn)的服務(wù)注冊(cè)中心模塊:register-demo

c.消費(fèi)方-配合ribbon和hystrix的模塊:consumer-ribbon-with-hystrix-demo

d.消費(fèi)方-配合feign和hystrix的模塊:consumer-feign-with-hystrix-demo


項(xiàng)目結(jié)構(gòu)

2.consumer-ribbon-with-hystrix-demo中的代碼說(shuō)明

pom.xml配置

分別加入了hystrix/ribbon/eureka的pom依賴


user類實(shí)體類

user類

RibbonHystrixController類

RibbonHystrixController類

RibbonHystrixService類

RibbonHystrixService類

在這個(gè)類中通過(guò)注解

@HystrixCommand(fallbackMethod = "fallback")

和實(shí)現(xiàn)的fallback方法來(lái)實(shí)現(xiàn)短路保護(hù)

public User fallback(Long id)?

啟動(dòng)類

通過(guò)注解@LoadBalanced

@Bean

@LoadBalanced

public RestTemplate restTemplate() { return new RestTemplate();}

實(shí)現(xiàn)調(diào)用方的負(fù)載均衡


測(cè)試實(shí)現(xiàn)效果

1.測(cè)試準(zhǔn)備

a.啟動(dòng)注冊(cè)中心服務(wù)register-demo

效果如下:

表示啟動(dòng)成功

b.在瀏覽器中訪問(wèn)地址:

http://localhost:8761/


能打開(kāi)頁(yè)面,表示啟動(dòng)成功趾代,從圖中可以看到贯底,目前沒(méi)有服務(wù)注冊(cè)進(jìn)來(lái)。

c.我們啟動(dòng)service-demo服務(wù)撒强,注意需要啟動(dòng)兩次service服務(wù)

注意在idea中默認(rèn)相同的服務(wù)禽捆,重復(fù)啟動(dòng)的話,會(huì)覆蓋之前的服務(wù)飘哨,如何啟動(dòng)兩個(gè)服務(wù)呢睦擂?請(qǐng)看下圖:


點(diǎn)擊Edit 菜單


將單列啟動(dòng)的限制勾選去掉,就可以了杖玲。注意顿仇,需要啟動(dòng)兩次,需要修改application.yml文件中的端口號(hào)


效果如下:


表示啟動(dòng)成功摆马,并加入到了注冊(cè)中心臼闻。


從圖中我們可以看到,在瀏覽器中已經(jīng)可以看到注冊(cè)上來(lái)的服務(wù)了囤采,并且這個(gè)服務(wù)有兩個(gè)節(jié)點(diǎn)

d.我們啟動(dòng)寫(xiě)好的consumer-ribbon-with-hystrix-demo服務(wù)

效果如下:


2.通過(guò)postmain調(diào)用接口測(cè)試

a.測(cè)試調(diào)用6次接口

http://localhost:8011/ribbon/2

結(jié)果:輸出是在每個(gè)控制臺(tái)打印三次日志


b.關(guān)掉所有服務(wù)的時(shí)候述呐,就會(huì)走到降級(jí)流程中




3.consumer-feign-with-hystrix-demo中的代碼說(shuō)明

這個(gè)的配置就不一一闡述秤茅,所有工程的代碼奕纫,請(qǐng)需要的同學(xué)從github中下載測(cè)試附迷。

在feign中使用hystrix斷路器的時(shí)候读存,一定要開(kāi)啟一個(gè)配置厨钻,如果沒(méi)有開(kāi)啟的話栈戳,默認(rèn)是關(guān)閉的牡彻,不會(huì)走斷路器腔呜。

如下圖:



代碼地址:

Github地址:點(diǎn)擊查看

https://github.com/xiangfajun/spring-cloud-microservice-demo


本文參考的文獻(xiàn)地址:

http://blog.didispace.com/spring-cloud-starter-dalston-2-3/

http://blog.didispace.com/spring-cloud-starter-dalston-2-2/

http://blog.didispace.com/spring-cloud-starter-dalston-4-1/

http://blog.didispace.com/spring-cloud-starter-dalston-4-2/

http://blog.didispace.com/spring-cloud-starter-dalston-4-3/

http://book.itmuch.com

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末棉磨,一起剝皮案震驚了整個(gè)濱河市江掩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖环形,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件策泣,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡抬吟,警方通過(guò)查閱死者的電腦和手機(jī)萨咕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)火本,“玉大人危队,你說(shuō)我怎么就攤上這事》⑶郑” “怎么了交掏?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)刃鳄。 經(jīng)常有香客問(wèn)我盅弛,道長(zhǎng),這世上最難降的妖魔是什么叔锐? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任挪鹏,我火速辦了婚禮,結(jié)果婚禮上愉烙,老公的妹妹穿的比我還像新娘讨盒。我一直安慰自己,他們只是感情好步责,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布返顺。 她就那樣靜靜地躺著,像睡著了一般蔓肯。 火紅的嫁衣襯著肌膚如雪遂鹊。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 50,084評(píng)論 1 291
  • 那天蔗包,我揣著相機(jī)與錄音秉扑,去河邊找鬼。 笑死调限,一個(gè)胖子當(dāng)著我的面吹牛舟陆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播耻矮,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼秦躯,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了淘钟?” 一聲冷哼從身側(cè)響起宦赠,我...
    開(kāi)封第一講書(shū)人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤陪毡,失蹤者是張志新(化名)和其女友劉穎米母,沒(méi)想到半個(gè)月后勾扭,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡铁瞒,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年妙色,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片慧耍。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡身辨,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出芍碧,到底是詐尸還是另有隱情煌珊,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布泌豆,位于F島的核電站定庵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏踪危。R本人自食惡果不足惜蔬浙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望贞远。 院中可真熱鬧畴博,春花似錦、人聲如沸蓝仲。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)袱结。三九已至亮隙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間擎勘,已是汗流浹背咱揍。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留棚饵,地道東北人煤裙。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像噪漾,于是被迫代替她去往敵國(guó)和親硼砰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容