1肉迫、如何打造一個(gè)自己的 OPEN API 開(kāi)篇

這篇文章詳細(xì)記錄了我如何實(shí)現(xiàn)一個(gè) OpenAPI 的艱辛歷程妓忍、我把 OpenAPI 從概念、設(shè)計(jì)尝苇、實(shí)現(xiàn)铛只、部署、測(cè)試糠溜、監(jiān)控的整個(gè)過(guò)程詳細(xì)的提供給大家學(xué)習(xí)和參考淳玩。

提綱

  • 如何打造一個(gè)自己的 OPEN API
  • 如何設(shè)計(jì)一個(gè)符合 RESTful 的 OpenAPI
  • 使用 .Net Core 實(shí)現(xiàn)自己的 OpenAPI
  • 使用 Java Spring Boot 實(shí)現(xiàn)自己的 OpenAPI
  • 如何提高 OpenAPI 健壯性
  • 如何實(shí)現(xiàn) OpenAPI 的高可用

OpenAPI 是什么?

Open API 即開(kāi)放 API,也稱(chēng)開(kāi)放平臺(tái)非竿。 所謂的開(kāi)放 API(OpenAPI)是服務(wù)型網(wǎng)站常見(jiàn)的一種應(yīng)用蜕着,網(wǎng)站的服務(wù)商將自己的網(wǎng)站服務(wù)封裝成一系列
API(Application Programming Interface,應(yīng)用編程接口)開(kāi)放出去红柱,供第三方開(kāi)發(fā)者使用承匣,這種行為就叫做開(kāi)放網(wǎng)站的 API,所開(kāi)放的 API 就被稱(chēng)作 OpenAPI(開(kāi)放 API )锤悄。

RESTful API 是什么?

什么是 REST韧骗?

Representational State Transfer,翻譯是”表現(xiàn)層狀態(tài)轉(zhuǎn)化”零聚∨郾可以總結(jié)為一句話(huà):REST 是所有 Web 應(yīng)用都應(yīng)該遵守的架構(gòu)設(shè)計(jì)指導(dǎo)原則些侍。
面向資源是 REST 最明顯的特征,對(duì)于同一個(gè)資源的一組不同的操作政模。資源是服務(wù)器上一個(gè)可命名的抽象概念岗宣,資源是以名詞為核心來(lái)組織的,首先關(guān)注的是名詞览徒。REST 要求狈定,必須通過(guò)統(tǒng)一的接口來(lái)對(duì)資源執(zhí)行各種操作。對(duì)于每個(gè)資源只能執(zhí)行一組有限的操作习蓬。

什么是 RESTful API纽什?

符合 REST 設(shè)計(jì)標(biāo)準(zhǔn)的 API,即 RESTful API躲叼。REST 架構(gòu)設(shè)計(jì)芦缰,遵循的各項(xiàng)標(biāo)準(zhǔn)和準(zhǔn)則,就是 HTTP 協(xié)議的表現(xiàn)枫慷,換句話(huà)說(shuō)让蕾,HTTP 協(xié)議就是屬于 REST 架構(gòu)的設(shè)計(jì)模式。比如或听,無(wú)狀態(tài)探孝,請(qǐng)求-響應(yīng)。誉裆。顿颅。

Swagger 是什么?

Swagger? 的目標(biāo)是為 REST APIs 定義一個(gè)標(biāo)準(zhǔn)的,與語(yǔ)言無(wú)關(guān)的接口足丢,使人和計(jì)算機(jī)在看不到源碼或者看不到文檔或者不能通過(guò)網(wǎng)絡(luò)流量檢測(cè)的情況下能發(fā)現(xiàn)和理解各種服務(wù)的功能粱腻。當(dāng)服務(wù)通過(guò) Swagger 定義,消費(fèi)者就能與遠(yuǎn)程的服務(wù)互動(dòng)通過(guò)少量的實(shí)現(xiàn)邏輯斩跌。類(lèi)似于低級(jí)編程接口绍些,Swagger 去掉了調(diào)用服務(wù)時(shí)的很多猜測(cè)。

OpenAPI 展示

Docker Engine 1
Docker Engine 2
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末耀鸦,一起剝皮案震驚了整個(gè)濱河市柬批,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌袖订,老刑警劉巖萝快,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異著角,居然都是意外死亡揪漩,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)吏口,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)奄容,“玉大人冰更,你說(shuō)我怎么就攤上這事“豪眨” “怎么了蜀细?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)戈盈。 經(jīng)常有香客問(wèn)我奠衔,道長(zhǎng),這世上最難降的妖魔是什么塘娶? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任归斤,我火速辦了婚禮,結(jié)果婚禮上刁岸,老公的妹妹穿的比我還像新娘脏里。我一直安慰自己,他們只是感情好虹曙,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布迫横。 她就那樣靜靜地躺著,像睡著了一般酝碳。 火紅的嫁衣襯著肌膚如雪矾踱。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,749評(píng)論 1 289
  • 那天疏哗,我揣著相機(jī)與錄音介返,去河邊找鬼。 笑死沃斤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的刃宵。 我是一名探鬼主播衡瓶,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼牲证!你這毒婦竟也來(lái)了哮针?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤坦袍,失蹤者是張志新(化名)和其女友劉穎十厢,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體捂齐,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蛮放,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了奠宜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片包颁。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡瞻想,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出娩嚼,到底是詐尸還是另有隱情蘑险,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布岳悟,位于F島的核電站佃迄,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏贵少。R本人自食惡果不足惜呵俏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望春瞬。 院中可真熱鬧柴信,春花似錦、人聲如沸宽气。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)萄涯。三九已至绪氛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間涝影,已是汗流浹背枣察。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留燃逻,地道東北人序目。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像伯襟,于是被迫代替她去往敵國(guó)和親猿涨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

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