[譯]不存在的REST API

原文:There is No REST API ? ?

譯者:杰微刊兼職翻譯汪建 ? ? ?

作者:Howard Dierking

最近我花了一些時間和我的團隊從API的角度來聊了REST的話題义桂,同樣也討論了如何利用諸如違反了REST的最重要原則的Swagger技術(shù)去創(chuàng)建API牧挣。正如我在討論中說的爷辱,那就是REST風(fēng)格不是用來描述API宇挫。REST描述了整個系統(tǒng)的架構(gòu)特性役首,用于描述此該系統(tǒng)包含了所有哪些不同組成的部分。它嘗試基于組件對系統(tǒng)提出系統(tǒng)級別的要求笨枯,甚至是對系統(tǒng)不起作用的一層瘟滨。

“我們對于REST風(fēng)格最大的幫倒忙的行為之一就是我們在REST后面添加了API字眼!”

目前我見過幾個不同公司的處理場景为牍,這些公司在最純粹的定義上將一個服務(wù)搭建成REST風(fēng)格哼绑,客戶端通過各種方式的使用讓系統(tǒng)變得非REST風(fēng)格岩馍。更糟的是,這使得人們更難在跟高層次上闡明REST的價值抖韩,因為“REST風(fēng)格”的API在易用性和長期穩(wěn)定性方面與RPC這方面的性能并沒有明顯的差異蛀恩。事實上,在某些情況下茂浮,某些性能會被認(rèn)為差得多双谆,比如可用性方面。

對于客戶端來說席揽,在REST風(fēng)格和非REST風(fēng)格的系統(tǒng)之間有兩個明顯的方式:URL結(jié)構(gòu)和文檔結(jié)構(gòu)顽馋。

正如我敢肯定的是你聽說過廣告令人厭倦,避免由客戶端構(gòu)造URL而是由服務(wù)端提供連接驹尼,這是REST風(fēng)格的超媒體的核心趣避,這使得服務(wù)器真正擁有它的所有資源的名稱和位置。從而使其能夠獨立于它的客戶端進行演變新翎。但是程帕,這僅僅當(dāng)客戶端使用服務(wù)端提供的連接時才有效,但更多地我比較愿意承認(rèn)地啰,在客戶端真實的編程時他們會忽略服務(wù)端連接愁拭,而是用基于URL(多次硬編碼)的連接在之前的響應(yīng)體中加上各種數(shù)據(jù)。Swagger工具(甚至GraphQL)鼓勵這種使用它們的URI膜拜和占位符的模式岭埠。

客戶端和服務(wù)器端之間更加隱藏的耦合是涉及到如何領(lǐng)會每個請求和響應(yīng)的有效負(fù)載,在REST理想世界中蔚鸥,客戶端和服務(wù)器都綁定到一個標(biāo)準(zhǔn)的IANA注冊的上下文類型中,而且不會嘗試去理解任何超過以上范圍的事情止喷,然而這不是我們生活的世界,它無疑不是我們希望生活的世界弹谁。業(yè)務(wù)系統(tǒng)通過他們的性質(zhì)乾巧、域特性等自然結(jié)果预愤,即使是在相同的域中的每個系統(tǒng)彼此之間都有稍微不同的方言。無論是對還是錯植康,這些差異是分化多次而作為競爭優(yōu)勢。此外销睁,業(yè)務(wù)(和支持他的數(shù)據(jù)視圖)可以根據(jù)各種因素在響應(yīng)中快速改變泳秀。你可以多頻繁地支持標(biāo)準(zhǔn)媒體型的變化?得知它是以年計的你可能不會感到驚訝嗜傅。

所以,如果一個客戶端和服務(wù)器不能依賴于綁定到一個標(biāo)準(zhǔn)的內(nèi)容類型去互相理解他們之間互相傳輸?shù)臄?shù)據(jù)的話吕嘀,那他們穩(wěn)定性還可以依賴什么呢违寞?恩偶房,就像法定貨幣一樣,沒有什么棕洋。

好吧挡闰,這無可否認(rèn)具有一點戲劇性。但問題是系統(tǒng)的穩(wěn)定性確實在服務(wù)器和客戶端之間沒有雙關(guān)語義的用于理解數(shù)據(jù)的協(xié)議掰盘。這些規(guī)則必須在某處記錄起來然后在客戶端和服務(wù)器進行編碼摄悯。規(guī)則可以用標(biāo)記或結(jié)構(gòu)化描述語言來記錄,并且他們可以直接在代碼中愧捕、在模式文檔中奢驯、在混合情況下進行編碼,從模式文檔中生成代碼次绘。對于所有的這些策略瘪阁、工具、技術(shù)邮偎,提醒著存在一個“數(shù)據(jù)合同”(從我的WCF日子中借用此概念)代表客戶端和服務(wù)端之間互相作用從而使得系統(tǒng)很穩(wěn)定管跺。任何數(shù)據(jù)合同的改變必然導(dǎo)致服務(wù)契約的改變。在更復(fù)雜的聯(lián)合服務(wù)中禾进,其實還是有很多客戶端綁定的小數(shù)據(jù)合同豁跑。鑒于這一事實,WSDL和Swagger合并文檔模式到API程序描述文檔可能是正確的命迈,將模式作為參數(shù)的類型(盡管我還是不同意這些大體上的策略)贩绕。

當(dāng)談及REST時火的,人們?nèi)绾螛?gòu)建客戶端真的是IMO的核心問題壶愤。在實踐中,REST風(fēng)格系統(tǒng)的前提是具有通用的客戶端馏鹤,對于我們正在做的系統(tǒng)這樣做可能是不切實際的征椒,市面上為什么只有這么少數(shù)量的瀏覽器的原因是,構(gòu)建瀏覽器是很難的湃累。然而勃救,這是因為標(biāo)準(zhǔn)內(nèi)容類型的復(fù)雜性碍讨,比如HTML和協(xié)議、HTTP和DNS蒙秒。它可以盡力基于潛在用戶而被調(diào)整的勃黍。就像對于業(yè)務(wù)系統(tǒng),甚至是一個很龐大的系統(tǒng)晕讲,它更加難以調(diào)整類似的覆获。尤其是當(dāng)需要創(chuàng)建(并獲得成功,更廣泛的行業(yè)支持)一個類似于HTML的標(biāo)準(zhǔn)內(nèi)容類型時瓢省。

所以弄息,當(dāng)我們討論API時,也許現(xiàn)在是時候要理智真誠地放棄使用“REST”術(shù)語了勤婚。這將可以讓我們停止圍繞著他們是否是真正的REST風(fēng)格上越包越多摹量,同時使我們能不覺得有必要拿出像“務(wù)實REST”條款÷ǎ或許我們應(yīng)該著眼于建設(shè)可用的Web API缨称。對我們用戶來說,可用性是重點国章。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末具钥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子液兽,更是在濱河造成了極大的恐慌骂删,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宁玫,死亡現(xiàn)場離奇詭異柑晒,居然都是意外死亡欧瘪,警方通過查閱死者的電腦和手機佛掖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門芥被,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人拴魄,你說我怎么就攤上這事∠氖” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵挂绰,是天一觀的道長扮授。 經(jīng)常有香客問我专肪,道長,這世上最難降的妖魔是什么嚎尤? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任芽死,我火速辦了婚禮,結(jié)果婚禮上关贵,老公的妹妹穿的比我還像新娘。我一直安慰自己落萎,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布练链。 她就那樣靜靜地躺著媒鼓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪绿鸣。 梳的紋絲不亂的頭發(fā)上暂氯,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音再登,去河邊找鬼晾剖。 笑死,一個胖子當(dāng)著我的面吹牛齿尽,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播绵估,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼卡骂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了缝左?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤渺杉,失蹤者是張志新(化名)和其女友劉穎是越,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體倚评,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡蔓纠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年吗蚌,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚯妇。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖箩言,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情陨收,我是刑警寧澤鸵赖,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布它褪,位于F島的核電站,受9級特大地震影響茫打,放射性物質(zhì)發(fā)生泄漏妖混。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一抬旺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嚷狞,春花似錦荣堰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽啃洋。三九已至,卻和暖如春宏娄,著一層夾襖步出監(jiān)牢的瞬間逮壁,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工卖宠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人扛伍。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓词裤,卻偏偏與公主長得像鳖宾,于是被迫代替她去往敵國和親逆航。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,828評論 2 345

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)赖瞒,斷路器,智...
    卡卡羅2017閱讀 134,599評論 18 139
  • 一說到REST吧兔,我想大家的第一反應(yīng)就是“啊袍嬉,就是那種前后臺通信方式∷磐ǎ”但是在要求詳細(xì)講述它所提出的各個約束,以及如...
    時待吾閱讀 3,410評論 0 19
  • 這世間吴藻,風(fēng)不動,樹也不會動沟堡,只有人心會動。 希望在20出頭的生命里航罗,做一件到八十歲想起來都還會微笑的事 別老低估自...
    她他社閱讀 498評論 0 1
  • 三行情書屁药,兩行清淚 夢里浮沉,過眼云煙
    彌貓ing閱讀 245評論 0 0
  • “繁茂的東山下立莉,美麗的威海灣,有我的樂園碼頭小學(xué)…… ”這首歌是我們的校歌蜓耻,早上來到學(xué)校就會想起這優(yōu)美的歌聲。 進...
    祁魯閱讀 393評論 0 0