談?wù)勎蚁胍腁PI網(wǎng)關(guān)

在當(dāng)前的系統(tǒng)架構(gòu)中熙卡,微服務(wù)架構(gòu)大行其道杖刷,在微服務(wù)架構(gòu)中一個(gè)很重要的組件就是API網(wǎng)關(guān)。

API網(wǎng)關(guān)是一個(gè)服務(wù)器驳癌,是系統(tǒng)的唯一入口滑燃。從面向?qū)ο笤O(shè)計(jì)的角度看,它與外觀(guān)模式類(lèi)似颓鲜。API網(wǎng)關(guān)封裝了系統(tǒng)內(nèi)部架構(gòu)表窘,為每個(gè)客戶(hù)端提供一個(gè)定制的API。它可能還具有其它職責(zé)甜滨,如身份驗(yàn)證乐严、監(jiān)控、負(fù)載均衡衣摩、緩存昂验、請(qǐng)求分片與管理、靜態(tài)響應(yīng)處理艾扮。 --百度

微服務(wù)本身當(dāng)然需要有效的監(jiān)控管理既琴,而API作為微服務(wù)對(duì)外提供的核心能力,同樣需要進(jìn)行細(xì)致泡嘴、高效的管控甫恩。
一個(gè)強(qiáng)大、高效酌予、可靠磺箕、可控的API網(wǎng)關(guān)可以極大的提升對(duì)整個(gè)系統(tǒng)架構(gòu)下的微服務(wù)API的梳理、管控能力抛虫,使得API用的放心松靡,管的舒心。
目前業(yè)界也有多款成熟的API網(wǎng)關(guān)可用:Kong莱褒、Zuul、Traefik涎劈、Spring
Cloud Gateway等等

  • Kong
    基于Nginx+Lua開(kāi)發(fā)广凸,性能高阅茶,穩(wěn)定,有多個(gè)可用的插件(限流谅海、鑒權(quán)等等)可以開(kāi)箱即用脸哀。
    問(wèn)題:只支持Http協(xié)議;二次開(kāi)發(fā)扭吁,自由擴(kuò)展困難撞蜂;提供管理API,缺乏更易用的管控侥袜、配置方式蝌诡。
  • Zuul
    Netflix開(kāi)源,功能豐富枫吧,使用JAVA開(kāi)發(fā)浦旱,易于二次開(kāi)發(fā);需要運(yùn)行在web容器中九杂,如Tomcat颁湖。
    問(wèn)題:缺乏管控,無(wú)法動(dòng)態(tài)配置例隆;依賴(lài)組件較多甥捺;處理Http請(qǐng)求依賴(lài)的是Web容器,性能不如Nginx镀层;
  • Traefik
    Go語(yǔ)言開(kāi)發(fā)镰禾;輕量易用;提供大多數(shù)的功能:服務(wù)路由鹿响,負(fù)載均衡等等羡微;提供WebUI
    問(wèn)題:二進(jìn)制文件部署,二次開(kāi)發(fā)難度大惶我;UI更多的是監(jiān)控妈倔,缺乏配置、管理能力绸贡;
  • Spring Cloud Gateway & Zuul2
    開(kāi)發(fā)完善中盯蝴,期待一下。听怕。捧挺。

綜合比較一番后,除了常規(guī)的API網(wǎng)關(guān)應(yīng)有的能力外尿瞭,(我的)理想中的API網(wǎng)關(guān)要有哪些能力呢闽烙?

  1. 協(xié)議轉(zhuǎn)換
    上游服務(wù)多種多樣,雖然現(xiàn)在流行Spring Cloud架構(gòu),直接提供Http協(xié)議的服務(wù)API黑竞,但是毫無(wú)疑問(wèn)捕发,還是后端系統(tǒng)間采用RPC調(diào)用的較多,如果API網(wǎng)關(guān)可以對(duì)此類(lèi)服務(wù)進(jìn)行協(xié)議轉(zhuǎn)換很魂,對(duì)外將其適配為HTTP接口扎酷,對(duì)內(nèi)仍為RPC調(diào)用,這無(wú)疑可以極大的提升系統(tǒng)整體性能遏匆,同時(shí)不用約束上游系統(tǒng)的實(shí)現(xiàn)方式法挨,雙贏(yíng)!
  2. 動(dòng)態(tài)配置
    API網(wǎng)關(guān)必然需要和多個(gè)系統(tǒng)打交道幅聘,一些配置工作如:路由映射凡纳,超時(shí)配置,服務(wù)地址喊暖,權(quán)重調(diào)整等等是必不可少的了惫企,動(dòng)態(tài)配置,動(dòng)態(tài)加載陵叽,實(shí)時(shí)生效是一個(gè)提升穩(wěn)定性的有效手段狞尔。
  3. 管控平臺(tái)
    API網(wǎng)關(guān)是一個(gè)承前啟后的重要節(jié)點(diǎn),其管理著大量的來(lái)自不同系統(tǒng)的API巩掺,每時(shí)每刻都會(huì)有大量的請(qǐng)求通過(guò)API網(wǎng)關(guān)到達(dá)不同的上游系統(tǒng)服務(wù)偏序,同樣有大量的響應(yīng)從上游回到API網(wǎng)關(guān),并最終發(fā)送給調(diào)用者胖替,除非所有服務(wù)的API永不出錯(cuò)研儒,否則一個(gè)高效的管控平臺(tái)必不可少!更重要的是不但要監(jiān)控独令,更可以管理端朵!

腦海中的Pampas

腦洞開(kāi)一開(kāi),我需要的API網(wǎng)關(guān)大概應(yīng)該是這個(gè)樣_

image.png

造出來(lái)

把想法實(shí)現(xiàn)出來(lái)是一件有意思的事燃箭。
附上github項(xiàng)目地址……
PAMPAS@github
PAMPAS-UI@github

歡迎貢獻(xiàn)Idea和Code

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末冲呢,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子招狸,更是在濱河造成了極大的恐慌敬拓,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件裙戏,死亡現(xiàn)場(chǎng)離奇詭異乘凸,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)累榜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)营勤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事葛作⌒训冢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵进鸠,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我形病,道長(zhǎng)客年,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任漠吻,我火速辦了婚禮量瓜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘途乃。我一直安慰自己绍傲,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布耍共。 她就那樣靜靜地躺著烫饼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪试读。 梳的紋絲不亂的頭發(fā)上杠纵,一...
    開(kāi)封第一講書(shū)人閱讀 52,475評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音钩骇,去河邊找鬼比藻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛倘屹,可吹牛的內(nèi)容都是我干的银亲。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼纽匙,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼务蝠!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起哄辣,我...
    開(kāi)封第一講書(shū)人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤请梢,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后力穗,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體毅弧,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年当窗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了够坐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖元咙,靈堂內(nèi)的尸體忽然破棺而出梯影,到底是詐尸還是另有隱情,我是刑警寧澤庶香,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布甲棍,位于F島的核電站,受9級(jí)特大地震影響赶掖,放射性物質(zhì)發(fā)生泄漏感猛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一奢赂、第九天 我趴在偏房一處隱蔽的房頂上張望陪白。 院中可真熱鬧,春花似錦膳灶、人聲如沸咱士。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)序厉。三九已至,卻和暖如春毕箍,著一層夾襖步出監(jiān)牢的瞬間脂矫,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工霉晕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留庭再,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓牺堰,卻偏偏與公主長(zhǎng)得像拄轻,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子伟葫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

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