rpc調(diào)用設(shè)計(jì)經(jīng)驗(yàn).md

rpc服務(wù)設(shè)計(jì)

包的劃分

  • xxx-api : api給調(diào)用方使用

  • xxx-core:業(yè)務(wù)實(shí)現(xiàn) 【具體可以再分吧】

  • xxx-job: 任務(wù)

  • xxx-web :部署 maven profile環(huán)境【沒有統(tǒng)一的配置中心】

接口設(shè)計(jì)原則:

異常區(qū)分

  • rpc框架異常

  • 系統(tǒng)異常

  • 業(yè)務(wù)異常

接口設(shè)計(jì)

  • 業(yè)務(wù)成功

  • 是否重試 【rpc框架配置】

  • 異常處理

基于dubbo的問題

A服務(wù)--> B服務(wù)

  • 中間網(wǎng)絡(luò)異常:訪問超時(shí)

  • B服務(wù)宕機(jī):訪問超時(shí)

  • B服務(wù)rpc框架異常:拋出rpc框架異常

  • B服務(wù)系統(tǒng)異常:內(nèi)部異臣跸福或者業(yè)務(wù)異常

dubbo服務(wù)為例靶橱,默認(rèn)重試2次饱普,如果有多個(gè)提供值默認(rèn)隨機(jī)選另外一個(gè),重試之內(nèi)在調(diào)不通調(diào)用b服務(wù)跑出RpcException,如果配置上mock降級琉苇,返回null,看業(yè)務(wù)

dubbo服務(wù)化最佳實(shí)戰(zhàn)

  • 分包: api,core柳畔,web; 建議將服務(wù)接口,服務(wù)模型郭赐,服務(wù)異常等均放在API包中

  • 粒度:服務(wù)接口盡可能大粒度薪韩,每個(gè)服務(wù)方法應(yīng)代表一個(gè)功能,而不是某功能的一個(gè)步驟捌锭,否則將面臨分布式事務(wù)問題俘陷,

服務(wù)分為:原子服務(wù)(訂單的crud等),核心(業(yè)務(wù))服務(wù)观谦,只做查詢的查詢服務(wù)等拉盾,接口 入?yún)?出參 要明確 拒絕:Map query(Map)

  • 版本:每個(gè)接口都應(yīng)該有版本號

  • 兼容性: 服務(wù)接口增加方法,或服務(wù)模型增加字段坎匿,可向后兼容(刪除方法或刪除字段盾剩,將不兼容雷激,枚舉類型新增字段也不兼容,需通過變更版本號升級)

  • 異常:處理RpcException框架異常告私,其他的不建議跑出異常屎暇,建議定義 code和msg描述問題,查找問題的時(shí)候在b服務(wù)的機(jī)器上面查詢驻粟,異常帶來反序列化等性能問題根悼,

RpcException問題看業(yè)務(wù)A---->B--->C,業(yè)務(wù)場景是否可以降級等

  • 服務(wù)的配置盡量在服務(wù)提供者方面配置完善蜀撑,考慮該服務(wù)相關(guān)問題

接口方法的是否重試挤巡,并發(fā)量,超時(shí)時(shí)間酷麦,是否mock, 復(fù)雜均衡策略矿卑,失效轉(zhuǎn)移策略,綜合接口是查詢沃饶,冪等等考慮

  • 分布式服務(wù)中母廷,所有的服務(wù)都可能不可靠,對一個(gè)服務(wù)內(nèi)的 調(diào)用確保一個(gè)服務(wù) 的相關(guān)業(yè)務(wù)

  • 服務(wù)級別:細(xì)粒度服務(wù)提供數(shù)據(jù)操作糊肤,不涉及業(yè)務(wù)的基礎(chǔ)服務(wù)琴昆,以及業(yè)務(wù)聚合服務(wù),避免分布式事務(wù)

分布式rpc調(diào)用分析

電商常用的 優(yōu)惠券馆揉,訂單服務(wù)业舍, 支付服務(wù)

  • 流程:
Paste_Image.png

三個(gè)獨(dú)立的服務(wù),單獨(dú)的db庫升酣;先來考慮下單的服務(wù)調(diào)用

  • 下單之前用戶必然要先選擇優(yōu)惠券舷暮,所以下單之前要調(diào)用扣減優(yōu)惠券走rpc調(diào)用(失敗到此結(jié)果提示扣減優(yōu)惠券失敗)噩茄,調(diào)用成功走用戶下單流程

  • 如果下單失敗脚牍,必然要回滾扣掉的優(yōu)惠券,怎么操作巢墅?走rpc添加優(yōu)惠券,如果此時(shí)優(yōu)惠券服務(wù)超時(shí)了就添加不成功了

這里可以利用券膀,消息隊(duì)列的特性(保證消息至少成功消費(fèi)一次)君纫,發(fā)一條添加剛才扣掉的優(yōu)惠券消息

  • 如果下單成功,就去支付芹彬,而此時(shí)支付成功但是返回結(jié)果的時(shí)候失敗了蓄髓?如何處理?一般此時(shí)的訂單就在支付中的狀態(tài)

支付失敗舒帮,提示支付失敗即可

  • 分布式rpc調(diào)用三種狀態(tài): 失敗会喝,成功陡叠, 超時(shí)(可能成功可能失敗需要特別思考)

分布式調(diào)用

非實(shí)時(shí)、非強(qiáng)一致性

  • 走mq消息實(shí)現(xiàn)方式:同時(shí)做好防止重復(fù)消費(fèi)肢执,冪等性等

實(shí)時(shí)枉阵,強(qiáng)一致性

  • 參考蘑菇街創(chuàng)建訂單流程
Paste_Image.png
  • 將分布式事務(wù),分解成多個(gè)本地事務(wù)预茄,然后結(jié)合mq回滾

  • 先創(chuàng)建一個(gè)狀態(tài)為:不可見的訂單兴溜,鎖定優(yōu)惠券(失敗)發(fā)送廢單消息

  • 鎖定優(yōu)惠券成功耻陕,扣減庫存(失斪净铡),也發(fā)送 廢單消息

  • 扣減庫存成功修改訂單為可見狀態(tài)

  • 只要是 廢單消息 消息(回庫存诗宣,回劵劵等)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末膘怕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子召庞,更是在濱河造成了極大的恐慌岛心,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件裁眯,死亡現(xiàn)場離奇詭異鹉梨,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)穿稳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門存皂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人逢艘,你說我怎么就攤上這事旦袋。” “怎么了它改?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵疤孕,是天一觀的道長。 經(jīng)常有香客問我央拖,道長祭阀,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任鲜戒,我火速辦了婚禮专控,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘遏餐。我一直安慰自己伦腐,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布失都。 她就那樣靜靜地躺著柏蘑,像睡著了一般幸冻。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上咳焚,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天洽损,我揣著相機(jī)與錄音,去河邊找鬼黔攒。 笑死趁啸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的督惰。 我是一名探鬼主播不傅,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼赏胚!你這毒婦竟也來了访娶?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤觉阅,失蹤者是張志新(化名)和其女友劉穎崖疤,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體典勇,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡劫哼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了割笙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片权烧。...
    茶點(diǎn)故事閱讀 40,015評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖伤溉,靈堂內(nèi)的尸體忽然破棺而出般码,到底是詐尸還是另有隱情,我是刑警寧澤乱顾,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布板祝,位于F島的核電站,受9級特大地震影響走净,放射性物質(zhì)發(fā)生泄漏券时。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一伏伯、第九天 我趴在偏房一處隱蔽的房頂上張望革为。 院中可真熱鬧,春花似錦舵鳞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抛虏。三九已至,卻和暖如春套才,著一層夾襖步出監(jiān)牢的瞬間迂猴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工背伴, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沸毁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓傻寂,卻偏偏與公主長得像息尺,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子疾掰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評論 2 355

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

  • 轉(zhuǎn)自:http://blog.csdn.net/kesonyk/article/details/50924489 ...
    晴天哥_王志閱讀 24,813評論 2 38
  • 有人的地方搂誉,就有江湖有江湖的地方,就有紛爭 問題的起源在電商等業(yè)務(wù)中静檬,系統(tǒng)一般由多個(gè)獨(dú)立的服務(wù)組成炭懊,如何解決分布式...
    linking12閱讀 2,375評論 0 35
  • “ 消息隊(duì)列已經(jīng)逐漸成為企業(yè)IT系統(tǒng)內(nèi)部通信的核心手段。它具有低耦合拂檩、可靠投遞侮腹、廣播、流量控制稻励、最終一致性等一系列...
    落羽成霜丶閱讀 3,988評論 1 41
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理父阻,服務(wù)發(fā)現(xiàn),斷路器钉迷,智...
    卡卡羅2017閱讀 134,657評論 18 139
  • #不一樣的31天# 越來越喜歡這個(gè)活動至非,每天有不一樣的主題,給自己做一個(gè)命題作文糠聪。 我是一個(gè)經(jīng)郴耐郑看天空的人,也是一...
    史終成長閱讀 628評論 0 0