ApiGateway構(gòu)建微服務(wù)

目的

  • 避免讓客戶端感知微服務(wù)邊界的存在
  • 不同的后端边锁、前端團(tuán)隊(duì)需要統(tǒng)一的接口設(shè)計移必、接入規(guī)范

思路

  • API網(wǎng)關(guān)是請求進(jìn)入系統(tǒng)的唯一節(jié)點(diǎn)
  • API網(wǎng)關(guān)負(fù)責(zé)服務(wù)請求路由及協(xié)議轉(zhuǎn)換
  • 它可能還具有其它職責(zé),如身份驗(yàn)證顾彰、權(quán)限控制首尼、負(fù)載均衡耙替、“請求整形”與管理

參考鏈接

https://www.nginx.com/blog/building-microservices-using-an-api-gateway/

功能

  1. 協(xié)議解析
    以透明的方式實(shí)現(xiàn)Http到Rpc調(diào)用的轉(zhuǎn)換:
    http請求到rpc調(diào)用實(shí)例的映射;
    無類型的參數(shù)轉(zhuǎn)換為帶類型的參數(shù)胶逢;


    api register
api request process
  1. 服務(wù)代理
  2. 組合調(diào)用
    dubbo attachement提供了一種從consumer到provider的隱式傳參機(jī)制


    attachement機(jī)制

dubbo notification機(jī)制

是擴(kuò)展的從provider向consumer的旁路消息機(jī)制厅瞎。
變更DubboCodec中encodeResponseData,增加notification寫入初坠;
變更DecodeableRpcResult中decode和簸,增加notification解析;
不同于attachement的傳遞屬性碟刺,默認(rèn)notification只傳遞給服務(wù)consumer不再向上傳遞锁保,對于特定的notification需要一直向上傳遞我們通過DubboFilter機(jī)制實(shí)現(xiàn)copy and write隱式的完成特定notfication的連續(xù)傳播


notificaton機(jī)制
  1. 安全驗(yàn)證
    目的:api gateway作為外部訪問api的唯一入口,需要盡可能的攔截掉非正常請求,解析出真實(shí)的設(shè)備/用戶信息爽柒,再向微服務(wù)發(fā)起調(diào)用吴菠。
    主要手段:設(shè)備識別;數(shù)字簽名浩村;
  2. 集中式日志與監(jiān)控
    ELK:Elasticsearch(日志檢索引擎,OLAP)做葵,Logstash(日志采集) Kibana(數(shù)據(jù)可視化)
    Zabbix(系統(tǒng)監(jiān)控和通知)
    使用es數(shù)據(jù)源,按照服務(wù)心墅、錯誤碼等維度聚合錯誤
  3. 敏捷開發(fā)工具
    靈感:SOAP使用WSDL進(jìn)行stub生成
    實(shí)現(xiàn):ApiParser解析得到了完備的接口信息蜂挪,基于這個信息我們采用模板技術(shù)(xslt/velocity/handlerbars),生成出java/oc/js的客戶端調(diào)用代碼嗓化,以及在線文檔棠涮;
  4. 熱發(fā)布(scan變?yōu)殡x線操作,推送ApiMethodInfo+Interface至apigateway,并動態(tài)創(chuàng)建新的代理實(shí)例刺覆,進(jìn)行熱替換)

附圖

在項(xiàng)目啟動的時候严肪,會連上zookeeper,進(jìn)入docker,下載docker項(xiàng)目中的Jar包谦屑,并解析內(nèi)容

apigw代碼結(jié)構(gòu)分析
apigw一次http請求調(diào)用多個api時序圖
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末驳糯,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子氢橙,更是在濱河造成了極大的恐慌酝枢,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件悍手,死亡現(xiàn)場離奇詭異帘睦,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)坦康,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進(jìn)店門竣付,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人滞欠,你說我怎么就攤上這事古胆。” “怎么了筛璧?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵逸绎,是天一觀的道長。 經(jīng)常有香客問我夭谤,道長棺牧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任沮翔,我火速辦了婚禮陨帆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘采蚀。我一直安慰自己疲牵,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布榆鼠。 她就那樣靜靜地躺著纲爸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪妆够。 梳的紋絲不亂的頭發(fā)上识啦,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天,我揣著相機(jī)與錄音神妹,去河邊找鬼颓哮。 笑死,一個胖子當(dāng)著我的面吹牛鸵荠,可吹牛的內(nèi)容都是我干的冕茅。 我是一名探鬼主播,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼蛹找,長吁一口氣:“原來是場噩夢啊……” “哼姨伤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起庸疾,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤乍楚,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后届慈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體徒溪,經(jīng)...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片振定。...
    茶點(diǎn)故事閱讀 38,716評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡花椭,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蹂季,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布高氮,位于F島的核電站,受9級特大地震影響顷牌,放射性物質(zhì)發(fā)生泄漏剪芍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一窟蓝、第九天 我趴在偏房一處隱蔽的房頂上張望罪裹。 院中可真熱鬧,春花似錦、人聲如沸状共。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽峡继。三九已至冯袍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間碾牌,已是汗流浹背康愤。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留舶吗,地道東北人征冷。 一個月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像誓琼,于是被迫代替她去往敵國和親资盅。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評論 2 350

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