服務(wù)注冊中心完結(jié)篇(四)

一、主要涵蓋內(nèi)容

1.服務(wù)端控制臺源碼環(huán)境搭建

2.服務(wù)端保存客戶端注冊信息

3.客戶端的心跳檢測機(jī)制

4.客戶端服務(wù)發(fā)現(xiàn)

5.ribbon負(fù)載均衡

二、服務(wù)端控制臺源碼環(huán)境搭建

nacos服務(wù)端源碼地址:https://github.com/alibaba/nacos

git clone下載后我這邊與之前搭建環(huán)境版本保持一致,切換到1.1.4版本:

啟動(dòng)console項(xiàng)目:

啟動(dòng)后直接報(bào)錯(cuò)阔涉,是因?yàn)閚acos默認(rèn)走cluster集群配置,而我們本地還沒配置集群環(huán)境

跟蹤報(bào)錯(cuò)代碼StartingSpringApplicationRunListener.logClusterConf():

那么只要STANDALONE_MODE為true,就可以走單機(jī)模式了哈打。

也就是讀取STANDALONE_MODE_PROPERTY_NAME的環(huán)境變量,那么我們再啟動(dòng)的時(shí)候修改環(huán)境變量就行了:

debug方式啟動(dòng)項(xiàng)目:

啟動(dòng)成功后訪問控制臺http://localhost:8848/nacos/#/login讯壶,初始賬號密碼:nacos/nacos

那么到此就恭喜你料仗,你這邊搭建好了源碼服務(wù)端環(huán)境。

三伏蚊、客戶端注冊服務(wù)接口

debug啟動(dòng)demo-a微服務(wù)立轧,客戶端自動(dòng)注冊調(diào)用NacosServiceRegistry.register方法,并打斷點(diǎn)進(jìn)行跟蹤:

接口地址為/nacos/v1/ns/instance,params將注冊需要的namespace躏吊、group氛改、clsuter信息都傳遞過去

此時(shí)服務(wù)端項(xiàng)目naming進(jìn)行斷點(diǎn)調(diào)試:

客戶端微服務(wù)基本注冊信息被接受進(jìn)來:

創(chuàng)建service并初始化service

同時(shí)service再init時(shí)候會(huì)開啟定時(shí)任務(wù)進(jìn)行心跳檢測

最后將service中包含了namespace、group等信息比伏,將service包裹成一個(gè)key,然后將instances列表放入consistencyService中:

四胜卤、客戶端心跳機(jī)制

客戶端微服務(wù)demo-a以debug方式啟動(dòng),定位到NacosNamingService.registerInstance

進(jìn)來服務(wù)端naming項(xiàng)目進(jìn)行斷點(diǎn)跟蹤:

該過程可以可以再次將客戶端注冊信息進(jìn)行重新注冊赁项,以防之前心跳失敗后被剔除列表

五葛躏、客戶端服務(wù)發(fā)現(xiàn)

這塊就不具體展開來詳細(xì)講解了澈段,以下為截圖跟進(jìn)具體的查詢邏輯:

前面我們跟蹤過了nacos-naming項(xiàng)目,

六舰攒、Ribbon負(fù)載均衡

Ribbon的使用只需要在RestTemplate上面加入注解@LoadBalanced既可實(shí)現(xiàn)服務(wù)發(fā)現(xiàn)

ribbin的負(fù)載均衡器默認(rèn)為ZoneAvoidanceRule,同時(shí)也可以在配置文件中進(jìn)行指定其它負(fù)載均衡策略

樣例:

以下是摘抄自網(wǎng)上的負(fù)載均衡策略整理:

接下來咋們跟蹤一下ribbon具體的處理邏輯败富,先找到自動(dòng)裝配類LoadBalancerAutoConfiguration:

進(jìn)入裝配類中查看:

同時(shí)后面配置了RestTemplateCustomizer定制化類:

最關(guān)鍵的就是LoadBalancerInterceptor攔截器了,接下來跟蹤一下調(diào)用

調(diào)用代碼:

瀏覽器訪問(demo-a微服務(wù)測試地址調(diào)用demo-b服務(wù)):http://localhost:8001/sayHello/123

原始訪問地址為http://demo-b/xxx:

跟蹤進(jìn)入ribbon的負(fù)載均衡邏輯摩窃,從服務(wù)列表中根據(jù)算法選擇一個(gè)server

RibbonLoadBalancerClient將uri地址進(jìn)行替換

好了兽叮,如果您看到這相信對整個(gè)nacos的服務(wù)端、客戶端猾愿、客戶端負(fù)載均衡應(yīng)該有了大致的了解了充择。整個(gè)nacos這塊先告一段落,后續(xù)文章中會(huì)繼續(xù)分享分布式事物處理方案匪蟀。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末椎麦,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子材彪,更是在濱河造成了極大的恐慌观挎,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件段化,死亡現(xiàn)場離奇詭異嘁捷,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)显熏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進(jìn)店門雄嚣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人喘蟆,你說我怎么就攤上這事缓升。” “怎么了蕴轨?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵港谊,是天一觀的道長。 經(jīng)常有香客問我橙弱,道長歧寺,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任棘脐,我火速辦了婚禮斜筐,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛀缝。我一直安慰自己顷链,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布内斯。 她就那樣靜靜地躺著蕴潦,像睡著了一般像啼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上潭苞,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天忽冻,我揣著相機(jī)與錄音,去河邊找鬼此疹。 笑死僧诚,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蝗碎。 我是一名探鬼主播湖笨,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蹦骑!你這毒婦竟也來了慈省?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤眠菇,失蹤者是張志新(化名)和其女友劉穎边败,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體捎废,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡笑窜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了登疗。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片排截。...
    茶點(diǎn)故事閱讀 39,688評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖辐益,靈堂內(nèi)的尸體忽然破棺而出断傲,到底是詐尸還是另有隱情,我是刑警寧澤荷腊,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布艳悔,位于F島的核電站急凰,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜羽杰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一瞬测、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧床三,春花似錦一罩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽差购。三九已至,卻和暖如春汉嗽,著一層夾襖步出監(jiān)牢的瞬間欲逃,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工饼暑, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留稳析,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓弓叛,卻偏偏與公主長得像彰居,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子撰筷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評論 2 353