欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

一種網(wǎng)絡(luò)應(yīng)用程序接口升級的方法及系統(tǒng)的制作方法

文檔序號:6503706閱讀:229來源:國知局
一種網(wǎng)絡(luò)應(yīng)用程序接口升級的方法及系統(tǒng)的制作方法
【專利摘要】本申請?zhí)峁┮环N網(wǎng)絡(luò)應(yīng)用程序接口升級的方法及系統(tǒng),其中,該方法包括:在升級啟動階段,生成與WebAPI的升級版本相對應(yīng)的第二定義信息,其中,第二定義信息被存儲在數(shù)據(jù)庫中,數(shù)據(jù)庫中還存儲與WebAPI的初始版本相對應(yīng)的第一定義信息,在升級線上測試階段,更新第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記WebAPI升級版本當(dāng)前為線上測試狀態(tài);在升級發(fā)布階段,更新第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記WebAPI升級版本當(dāng)前為已發(fā)布狀態(tài),如果WebAPI為兼容性升級,則在升級發(fā)布階段,更新第一定義信息中的發(fā)布狀態(tài)信息以標(biāo)記WebAPI的初始版本為已過期。采用本申請,可同時支持兼容性升級和非兼容性升級,并能實(shí)現(xiàn)線上測試環(huán)境和線上正式環(huán)境下WebAPI的隔離及自動切換。
【專利說明】一種網(wǎng)絡(luò)應(yīng)用程序接口升級的方法及系統(tǒng)

【技術(shù)領(lǐng)域】
[0001] 本申請涉及互聯(lián)網(wǎng)領(lǐng)域,尤其涉及一種網(wǎng)絡(luò)應(yīng)用程序接口升級的方法及系統(tǒng)。

【背景技術(shù)】
[0002] 在開放平臺領(lǐng)域,Web API (網(wǎng)絡(luò)應(yīng)用程序接口)一旦發(fā)布上線后,會被大量的外部 應(yīng)用調(diào)用,而發(fā)布后的Web API由于新增功能或者修復(fù)缺陷等原因不可避免的需要進(jìn)行升 級,然而,對于已發(fā)布的Web API進(jìn)行升級,會帶來以下三個問題:1)對于兼容性升級,如何 做到對外部應(yīng)用的透明性,即,在不強(qiáng)迫外部應(yīng)用改變原有Web API調(diào)用方式的前提下,使 兼容性升級自動生效,同時對于內(nèi)部網(wǎng)關(guān)來說,又可以區(qū)分兼容性升級前后的Web API,以 便做不同的內(nèi)部處理;2)對于非兼容性升級,如何做到升級前和升級后的Web API的隔離 性,既不影響那些已經(jīng)調(diào)用升級前的Web API的外部應(yīng)用的正常運(yùn)行,同時,又能由外部應(yīng) 用自行選擇是否調(diào)用升級后的Web API ;3)如何做到線上測試環(huán)境和線上正式環(huán)境的Web API隔離以及切換,S卩,在線上測試環(huán)境中,可以使用線上真實(shí)的請求對升級后的Web API 進(jìn)行測試驗(yàn)證,而在測試期間,線上正式環(huán)境仍然使用升級前的Web API,測試通過發(fā)布后, 線上正式環(huán)境使用的Web API自動切換為升級后的版本。
[0003] 目前的Web API升級方法主要有以下三種方案:第一種是升級后采用新的Web API名稱;第二種是給Web API加一個版本屬性,升級后更新版本號,應(yīng)用調(diào)用時需要同時 傳遞Web API名稱和版本號兩個信息;第三種是升級后不改變Web API的任何標(biāo)示信息,包 括名稱和版本等。
[0004] 現(xiàn)有的技術(shù)方案的第一種和第二種,因?yàn)槊看紊壓蠖紩耊eb API的標(biāo)示信 息(第一種改變名稱信息,第二種改變版本信息),而Web API的標(biāo)示信息恰恰包含在外部 應(yīng)用的請求參數(shù)中,因此,升級后會影響已有應(yīng)用對Web API原有的使用方式。例如,對 于現(xiàn)有的第一種方案,由于每次Web API升級后都會修改名稱,這會導(dǎo)致Web API名稱泛 濫,并且,有些Web API的名稱代表了該Web API特定的功能、作用等,改變名稱后,無法 體現(xiàn)出Web API的內(nèi)在含義。對于現(xiàn)有的第二種方案,例如,原來的外部應(yīng)用調(diào)用方式如 T* :https://openapi. xxxxx. com/gateway. do?method=abcd. efgh. hijk&version=l. O&us er_id=2012123456789123, Web API進(jìn)行兼容性升級后版本號變?yōu)?. 0,那么對于已有的 應(yīng)用,如果不能接受這個缺陷,就必須將原來的Web API調(diào)用參數(shù)中的版本號由1.0改為 2. 0,艮P,調(diào)用方式改變?yōu)椋篽ttps://openapi. xxxxx. com/gateway. do?method=abcd. efgh. hijk&version=2. O&us er_id=2012123456789123。而這對于兼容性升級來說,是不可接受 的,因?yàn)橐坏┰揥eb API已被大量的外部應(yīng)用使用后,再強(qiáng)迫所有的這些應(yīng)用進(jìn)行改造的代 價是巨大的。
[0005] 現(xiàn)有方案的第三種,對于兼容性升級,雖然對外部應(yīng)用來說是透明的,但由于升 級前和升級后的Web API的標(biāo)示信息是完全相同的,對內(nèi)部的網(wǎng)關(guān)來說升級前后的Web API是無法區(qū)分的,網(wǎng)關(guān)無法針對升級前和升級后的Web API做不同的處理,例如,網(wǎng)關(guān)無 法將升級前和升級后的Web API路由到不同的目標(biāo)系統(tǒng)。另外,兼容性升級前后的Web API的返回結(jié)果可能會出現(xiàn)不一樣,譬如升級后的Web API的返回結(jié)果增加了一個返回 屬性,外部應(yīng)用的開發(fā)者可能就會感到疑惑,因?yàn)殚_發(fā)者從返回結(jié)果中無從知道Web API 是否進(jìn)行過兼容性升級,不利于快速排查問題;而對于非兼容性升級,是不可接受的。例 如,某Web API返回的結(jié)果里包含有用戶的郵箱地址屬性,原來這個屬性是一個字符串類 型:{ "email" :"XXX@X. com"},應(yīng)用以字符串的方式使用該屬性。之后,由于用戶可以 有多個郵箱地址,因此對該Web API進(jìn)行非兼容性升級,將郵箱地址屬性改為列表類型 { "email": [ "χχχ@χ· com","yyy@x. com"]},那么就會破壞原來以字符串方式使用該屬性 的應(yīng)用的運(yùn)行。
[0006] 同時,由于線上測試環(huán)境和線上正式環(huán)境使用的是同一份數(shù)據(jù),采用上述三種方 法對Web API進(jìn)行升級后,會立即同時影響線上測試環(huán)境和線上正式環(huán)境,因此無法做到線 上測試環(huán)境和線上正式環(huán)境之間的Web API隔離,一旦升級后的Web API引發(fā)比較嚴(yán)重的 缺陷,會給線上正式環(huán)境帶來很大的影響。


【發(fā)明內(nèi)容】

[0007] 為解決上述問題本申請?zhí)峁┮环N網(wǎng)絡(luò)應(yīng)用程序接口 Web API升級的方法,以實(shí)現(xiàn) 同時支持兼容性升級和非兼容性升級,以及升級過程中線上測試環(huán)境和線上正式環(huán)境的隔 離,其中:網(wǎng)絡(luò)應(yīng)用程序接口(Web API)升級的方法,包括:在對Web API進(jìn)行升級的升級啟 動階段,生成與所述Web API的升級版本相對應(yīng)的第二定義信息,其中,所述第二定義信息 被存儲在數(shù)據(jù)庫中,所述數(shù)據(jù)庫中還存儲與所述Web API的初始版本相對應(yīng)的第一定義信 息,并且其中,所述第一和第二定義信息分別至少包括:Web API的名稱、主版本號、子版本 號、發(fā)布狀態(tài)信息以及路由信息;在對所述Web API的升級版本進(jìn)行線上測試的升級線上 測試階段,更新所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的 發(fā)布狀態(tài)為線上測試狀態(tài);在對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,更新 所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為已發(fā) 布狀態(tài),并且其中,如果所述Web API的升級類型為兼容性升級,則在所述升級發(fā)布階段,更 新所述第一定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API的初始版本為已過期。
[0008] 根據(jù)本申請的實(shí)施例,在該方法中,如果所述Web API的升級類型為兼容性升級, 則將所述第二定義信息中的主版本號生成為與所述第一定義信息中相同的主版本號,將所 述第二定義信息中的子版本號生成為所述第一定義信息中的子版本號不同的子版本號;如 果所述Web API的升級類型為非兼容性升級,則將所述第二定義信息中的主版本號生成為 所述第一定義信息中的主版本號不同的主版本號,將所述第二定義信息中的子版本號生成 為與所述第一定義信息中相同的子版本號。
[0009] 根據(jù)本申請的實(shí)施例,在該方法中,當(dāng)接收到對所述Web API的調(diào)用請求時,如果 所述請求是線上測試環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且 發(fā)布狀態(tài)為線上測試狀態(tài)的所述Web API的定義信息,如果查找不到,則在所述數(shù)據(jù)庫中查 找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信 息;如果所述請求是線上正式環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息 相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信息;其中,所述調(diào)用信息至少包 括:所調(diào)用Web API的名稱、主版本號。
[0010] 根據(jù)本申請的實(shí)施例,在該方法中,基于查找到的定義信息確定處理所述調(diào)用請 求的目標(biāo)系統(tǒng),將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng)對所述請求進(jìn)行 處理;接收來自目標(biāo)系統(tǒng)對所述請求的處理結(jié)果。
[0011] 本申請的另一方面還提供一種網(wǎng)絡(luò)應(yīng)用程序接口(Web API)升級的系統(tǒng),包括:信 息生成模塊,用于在對Web API進(jìn)行升級的升級啟動階段,生成與升級后得到所述Web API 的升級版本相對應(yīng)的第二定義信息,其中,所述第二定義信息被存儲在數(shù)據(jù)庫中,所述數(shù)據(jù) 庫中還存儲與所述Web API的初始版本相對應(yīng)的第一定義信息,并且其中,所述第一和第 二定義信息分別至少包括:Web API的名稱、主版本號、子版本號、發(fā)布狀態(tài)信息以及路由信 息;信息更新模塊,用于在對所述Web API的升級版本進(jìn)行線上測試的升級線上測試階段, 更新所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為 線上測試狀態(tài);以及用于在對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,更新所 述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為已發(fā)布 狀態(tài),并且其中,如果所述Web API的升級類型為兼容性升級,所述信息更新模塊還用于在 所述升級發(fā)布階段,更新所述第一定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API的初始 版本為已過期。
[0012] 根據(jù)本申請的實(shí)施例,在該系統(tǒng)中,所述信息生成模塊還用于:當(dāng)所述Web API的 升級類型為兼容性升級時,將所述第二定義信息中的主版本號生成為與所述第一定義信息 中相同的主版本號,將所述第二定義信息中的子版本號生成為所述第一定義信息中的子版 本號不同的子版本號;當(dāng)所述Web API的升級類型為非兼容性升級時,將所述第二定義信 息中的主版本號生成為所述第一定義信息中的主版本號不同的主版本號,將所述第二定義 信息中的子版本號生成為與所述第一定義信息中相同的子版本號。
[0013] 根據(jù)本申請的實(shí)施例,在該系統(tǒng)中,還包括:信息查找模塊,用于當(dāng)接收到對所述 Web API的調(diào)用請求時,如果所述請求是線上測試環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用 請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為線上測試狀態(tài)的所述Web API的定義信息,如果查 找不到,則在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布 狀態(tài)的所述Web API的定義信息;如果所述請求是線上正式環(huán)境的,在所述數(shù)據(jù)庫中查找 與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信 息;其中,所述調(diào)用信息至少包括:所調(diào)用Web API的名稱、主版本號。
[0014] 根據(jù)本申請的實(shí)施例,在該系統(tǒng)中,還包括:確定模塊,用于基于查找到的定義信 息確定目標(biāo)系統(tǒng);轉(zhuǎn)發(fā)模塊,用于將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng) 對所述請求進(jìn)行處理;接收模塊,用于接收來自目標(biāo)系統(tǒng)對所述請求的處理結(jié)果。
[0015] 與現(xiàn)有技術(shù)相比,根據(jù)本申請的技術(shù)方案,在兼容性升級時,外部應(yīng)用在調(diào)用已升 級的Web API時,不需要修改已有的調(diào)用方式,就能獲得Web API升級后的結(jié)果;同時,在 處理外部應(yīng)用對所述Web API的調(diào)用請求時,對于升級前和升級后的Web API是可區(qū)分的。 對于非兼容性升級,外部應(yīng)用只需要在請求參數(shù)里指明Web API升級后的主版本號,就能獲 得該Web API升級后的結(jié)果,不會影響那些已經(jīng)調(diào)用該Web API升級前版本的外部應(yīng)用的 運(yùn)行。另外,根據(jù)本申請的技術(shù)方案,可以實(shí)現(xiàn)線上測試環(huán)境和線上正式環(huán)境下Web API的 隔離,并且,當(dāng)線上測試環(huán)境驗(yàn)證通過后,線上正式環(huán)境使用的Web API能夠自動切換為升 級后的Web API的升級版本。

【專利附圖】

【附圖說明】
[0016] 此處所說明的附圖用來提供對本申請的進(jìn)一步理解,構(gòu)成本申請的一部分,本申 請的示意性實(shí)施例及其說明用于解釋本申請,并不構(gòu)成對本申請的不當(dāng)限定。在附圖中:
[0017] 圖1是本申請實(shí)施例涉及的網(wǎng)絡(luò)應(yīng)用程序接口(Web API)升級的方法流程圖;
[0018] 圖2是本申請實(shí)施例的對Web API進(jìn)行兼容性升級時第一定義信息和第二定義信 息在升級的各個階段的更新情況示意圖;
[0019] 圖3是本申請實(shí)施例的對Web API進(jìn)行非兼容性升級時第一定義信息和第二定義 信息在升級的各個階段的更新情況示意圖;
[0020] 圖4是本申請實(shí)施例的對Web API進(jìn)行升級過程中接收到對所述Web API的調(diào)用 請求時對所述請求進(jìn)行處理的流程圖;
[0021] 圖5是本申請實(shí)施例的對外部應(yīng)用的調(diào)用請求進(jìn)行處理的一個實(shí)例的處理流程 的不意圖;以及
[0022] 圖6是本申請實(shí)施例涉及的一種網(wǎng)絡(luò)應(yīng)用程序接口升級的系統(tǒng)的框圖。

【具體實(shí)施方式】
[0023] 為使本申請的目的、技術(shù)方案和優(yōu)點(diǎn)更加清楚,以下結(jié)合附圖及具體實(shí)施例,對本 申請作進(jìn)一步地詳細(xì)說明。
[0024] 根據(jù)本申請的實(shí)施例,提供了一種網(wǎng)絡(luò)應(yīng)用程序接口升級的方法及系統(tǒng)。
[0025] 參考圖1,圖1是本申請實(shí)施例涉及的網(wǎng)絡(luò)應(yīng)用程序接口升級的方法的流程圖。如 圖1所示,當(dāng)進(jìn)行網(wǎng)絡(luò)應(yīng)用程序接口(Web API)的升級時,在步驟S101中,在對所述Web API 進(jìn)行升級的升級啟動階段,生成與所述Web API的升級版本相對應(yīng)的第二定義信息,其中, 所述第二定義信息被存儲在數(shù)據(jù)庫中;所述數(shù)據(jù)庫中還存儲有與Web API的初始版本相對 應(yīng)的第一定義信息。所述第一、第二定義信息分別至少可以包括:所述Web API的名稱、主 版本號、子版本號、發(fā)布狀態(tài)信息以及路由信息等,即所述第一定義信息中,記錄所述Web API的初始版本的主版本號、子版本號、發(fā)布狀態(tài)信息以及路由信息等,例如,將某Web API 的第一定義信息記錄成:"名稱:X,主版本號:1. 〇,子版本號〇. 1,發(fā)布狀態(tài):已發(fā)布……"。 其中,發(fā)布狀態(tài)信息可以表示所述Web API初始版本或升級版本當(dāng)前的發(fā)布狀態(tài),例如,某 Web API初始版本已經(jīng)正式發(fā)布,當(dāng)前正在使用,則可以將該Web API的第一定義信息中的 發(fā)布狀態(tài)信息記為"已發(fā)布"。例如,某Web API升級版本當(dāng)前處在升級啟動階段,可以將所 述Web API第二定義信息中的所述Web API升級版本的發(fā)布狀態(tài)信息記為"初始化",當(dāng)所 述Web API的升級進(jìn)行到線上測試階段,可以將所述Web API的發(fā)布狀態(tài)記為"線上測試", 對所述發(fā)布狀態(tài)信息的記錄方式,本申請不做限定,例如,還可以以數(shù)字、字母、符號等字符 來標(biāo)記。所述Web API的名稱在升級前后保持不變,所述Web API的主版本號和子版本號 可以根據(jù)所述Web API的升級類型來確定。
[0026] 其中,如果所述Web API的升級類型為兼容性升級,則將所述第二定義信息中的主 版本號生成為與所述第一定義信息中相同的主版本號,將所述第二定義信息中的子版本號 生成為所述第一定義信息中的子版本號不同的子版本號。
[0027] 例如:當(dāng)某個Web API進(jìn)行兼容性升級時,將待升級的Web API的初始版本相對應(yīng) 的第一定義信息中主版本號記為1. 0、子版本號記為0. 1,將所述Web API升級得到的所述 Web API的升級版本,則將所述Web API的第二定義信息中的主版本號仍然記為1.0,而子 版本號記為與第一定義信息中不同的子版本號,例如,可以在原來的子版本號〇. 1的基礎(chǔ) 上累加0. 1,記為0. 2。
[0028] 當(dāng)對所述Web API進(jìn)行調(diào)用時,例如,外部應(yīng)用對所述Web API的調(diào)用,由于在Web API的定義信息中主版本號信息,還包括子版本號信息,而外部應(yīng)用在進(jìn)行Web API的調(diào)用 時,一般都會引用Web API的版本號信息,S卩,主版本號信息,而在兼容性升級中,升級后的 Web API,主版本號是不變的,而子版本號升級后記錄為與原來不同的子版本號,因此,夕卜部 應(yīng)用在調(diào)用兼容性升級的Web API時,不需要改變調(diào)用參數(shù)(方式),就可以調(diào)用到升級之后 的Web API升級版本,而內(nèi)部網(wǎng)關(guān)接收到外部應(yīng)用的調(diào)用請求時,則可以由Web API的定義 信息中的子版本號來區(qū)分對所述Web API升級前后的Web API初始版本和升級版本。
[0029] 而如果所述Web API的升級類型為非兼容性升級,則將所述第二定義信息中的主 版本號生成為所述第一定義信息中的主版本號不同的主版本號,將所述第二定義信息中的 子版本號生成為與所述第一定義信息中相同的子版本號。
[0030] 例如,當(dāng)某個Web API進(jìn)行非兼容性升級時,將待升級的Web API的初始版本相對 應(yīng)的第一定義信息中主版本號記為1. 〇,子版本號記為〇. 1,將所述進(jìn)行Web API升級得到 所述Web API的升級版本,則將所述Web API的第二定義信息中的主版本號記為與第一定 義信息中不同,例如,可以在原來的主版本號1. 〇的基礎(chǔ)上累加1記為2. 0,而子版本號不需 改變,可以記為與第一定義信息中相同的子版本號〇. 1。
[0031] 由于外部應(yīng)用在進(jìn)行Web API的調(diào)用時,一般引用的是Web API的主版本號信息, 而在非兼容性升級時,所述Web API的第二定義信息中記錄的所述Web API的升級版本的 主版本號與所述Web API的第一定義信息中記錄的所述Web API的初始版本的主版本號是 不同的,因此,外部應(yīng)用在調(diào)用該升級的Web API時,如果還以原來的調(diào)用參數(shù)調(diào)用該Web API時,則得到的還是所述Web API的初始版本,如果用戶想要使用升級后Web API,即,所 述Web API的升級版本,則需要將調(diào)用請求中引用的主版本號改為所述Web API升級版本 的主版本號,這樣可以使用戶對是否使用升級后的Web API進(jìn)行選擇。
[0032] 在步驟S102中,在對所述Web API的升級版本進(jìn)行線上測試的升級線上測試階 段,更新所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布 狀態(tài)為線上測試狀態(tài)。例如,原來的第二定義信息為"名稱:X、主版本號:1. 〇、子版本號: 〇. 2、發(fā)布狀態(tài):初始化、……",進(jìn)入線上測試階段后則可以將發(fā)布狀態(tài)信息更新為"線上 測試",即,第二定義信息更新為"名稱:X、主版本號:1. 0、子版本號:〇. 2、發(fā)布狀態(tài):線上測 試、……"此階段,由于Web API的升級版本沒有正式發(fā)布,因此,Web API的初始版本仍然 在線上正式環(huán)境中使用,即沒有過期,第一定義信息中的發(fā)布狀態(tài)信息不變,例如,原來記 錄的第一定義信息為"名稱:X、主版本號:1. 〇、子版本號:〇. 1、發(fā)布狀態(tài):已發(fā)布、……"而 該Web API的升級版本沒有正式發(fā)布,則在線上正式環(huán)境下使用的仍然是該Web API的初 始版本,則第一定義信息中的發(fā)布狀態(tài)信息仍然為"已發(fā)布"。
[0033] 在步驟S103中,在對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,更新所 述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為已發(fā)布 狀態(tài)。例如,在上一階段,第二定義信息為"名稱:X、主版本號:1. 〇、子版本號:〇. 2、發(fā)布狀 態(tài):線上測試、……"進(jìn)入了發(fā)布階段則可以將發(fā)布狀態(tài)信息更新為"已發(fā)布"即,第二定義 信息更新為"名稱:x、主版本號:1. 0、子版本號:〇. 2、發(fā)布狀態(tài):已發(fā)布、……"。在兼容性 升級時,在升級發(fā)布階段,由于Web API的升級版本已經(jīng)正式發(fā)布,因此,Web API的初始版 本已經(jīng)過期,第一定義信息中的發(fā)布狀態(tài)信息需要更新,以標(biāo)記所述Web API的初始版本的 已過期。例如,原來記錄的第一定義信息為"名稱:X、主版本號:1. 0、子版本號:〇. 1、發(fā)布狀 態(tài):已發(fā)布、……"而該Web API的升級版本正式發(fā)布時,則第一定義信息中的發(fā)布狀態(tài)信 息更新為"已過期"。
[0034] 下面結(jié)合圖2、圖3分別對兼容性升級和非兼容性升級的升級過程中第一定義信 息和第二定義信息在升級的各個階段的更新情況進(jìn)行詳細(xì)說明。
[0035] 圖2為進(jìn)行兼容性升級時,第一定義信息和第二定義信息在升級的各個階段的更 新情況示意圖,如圖2所示:
[0036] 首先,記錄Web API的初始版本(未升級過)的第一定義信息(R1),可以將主版本 號和子版本號分別記錄為1.0和〇. 1,發(fā)布狀態(tài)可以記錄為:已發(fā)布。
[0037] Web API從升級到發(fā)布上線歷經(jīng)三個過程:升級啟動、線上測試和發(fā)布。兼容性升 級的升級流程中Web API定義信息的變化分別如下:
[0038] 在對Web API進(jìn)行升級的升級啟動階段,針對Web API的升級版本,記錄相應(yīng)的第 二定義信息(R2),與第一定義信息R1相比,第二定義信息R2中的主版本號保持不變,仍為 1. 〇,子版本累加〇. 1,更新為〇. 2,狀態(tài)可以記錄為"初始化",而第一定義信息R1的任何信 息均保持不變。
[0039] 在對Web API的升級版本進(jìn)行線上測試的升級線上測試階段,該Web API的升級 版本沒有正式發(fā)布,初始版本還在線上正式環(huán)境中使用,因此,第一定義信息R1中的信息 均保持不變,狀態(tài)信息仍然記為與升級啟動階段相同的"已發(fā)布"狀態(tài)。而Web API的升級 版本的發(fā)布狀態(tài)變?yōu)榫€上測試狀態(tài),因此,可以將第二定義信息R2中的發(fā)布狀態(tài)信息由原 來的"初始化"更新為現(xiàn)階段的狀態(tài),例如,可以記為"線上測試"。
[0040] 對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,該Web API的升級版本已 經(jīng)正式發(fā)布,因此,將R2中的發(fā)布狀態(tài)信息由"線上測試"更新為"已發(fā)布",那么,Web API 的初始版本已經(jīng)過期,因此將R1中的發(fā)布狀態(tài)信息由"已發(fā)布"更新為"已過期"。
[0041] 圖3為進(jìn)行非兼容性升級時,第一定義信息和第二定義信息在升級的各個階段的 更新情況的示意圖,如圖3所示:
[0042] 首先,針對Web API的初始版本(未升級過)記錄第一定義信息(R1),可以將主版 本號和子版本號分別記錄為1.0和〇. 1,發(fā)布狀態(tài)可以記錄為:已發(fā)布。
[0043] Web API從升級到發(fā)布上線歷經(jīng)三個過程:升級啟動、線上測試和發(fā)布。非兼容性 升級的升級流程中Web API定義信息的變化分別如下:
[0044] 在對Web API進(jìn)行升級的升級啟動階段,針對Web API的升級版本,記錄相應(yīng)的第 二定義信息(R2),與第一定義信息R1相比,第二定義信息R2中的主版本號可以累加1,記 為2. 0,子版本號不變,仍然記為0. 1,發(fā)布狀態(tài)可以記錄為"初始化"。而對于第一定義信 息,在非兼容性升級中,整個升級的過程中第一定義信息R1的任何信息均保持不變。
[0045] 在對Web API的升級版本進(jìn)行線上測試的升級線上測試階段,R1中狀態(tài)信息仍然 記為"已發(fā)布"狀態(tài)。此階段Web API的升級版本的發(fā)布狀態(tài)變?yōu)榫€上測試狀態(tài),因此,可 以將第二定義信息R2中的發(fā)布狀態(tài)信息由原來的"初始化"更新為現(xiàn)階段的狀態(tài),可以記 為"線上測試"。
[0046] 對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,R1中狀態(tài)信息仍然記為 "已發(fā)布"狀態(tài),所述Web API的升級版本已經(jīng)正式發(fā)布,因此,將R2中的發(fā)布狀態(tài)信息由 "線上測試"更新為"已發(fā)布"。
[0047] 在對Web API進(jìn)行升級的過程中,如果接收到對所述Web API的調(diào)用請求,可以根 據(jù)調(diào)用請求中的調(diào)用信息(Web API名稱和主版本號)以及調(diào)用請求的環(huán)境(例如,線上測試 環(huán)境或線上正式環(huán)境)在數(shù)據(jù)庫中查找相應(yīng)的所述Web API的定義信息,并基于查找到的定 義信息確定目標(biāo)系統(tǒng),并將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng)對所述 請求進(jìn)行處理??扇鐖D4所示,圖4為在對Web API進(jìn)行升級過程中接收到對所述Web API 的調(diào)用請求時對所述調(diào)用請求進(jìn)行處理的流程圖,如圖4所示,
[0048] 在步驟S401中,接收對所述Web API的調(diào)用請求,基于所述調(diào)用請求查找相應(yīng)的 所述Web API的定義信息。
[0049] 查找規(guī)則為:如果所述請求是線上測試環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用 請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為線上測試狀態(tài)的所述Web API的定義信息,如果查 找不到,則在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布 狀態(tài)的所述Web API的定義信息;如果所述請求是線上正式環(huán)境的,在所述數(shù)據(jù)庫中查找 與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信 肩、。
[0050] 在兼容性升級的升級線上測試階段,所述第一定義信息中Web API的初始版本的 發(fā)布狀態(tài)為"已發(fā)布",所述第二定義信息中Web API的升級版本的發(fā)布狀態(tài)為"線上測試", 當(dāng)外部應(yīng)用以不變的調(diào)用參數(shù)(調(diào)用Web API的初始版本時的調(diào)用參數(shù),例如,調(diào)用名稱為 aaa.bbb.ccc,主版本號1.0的Web API),發(fā)起調(diào)用所述Web API的請求,如果所述調(diào)用請求 是在線上測試環(huán)境中處理的,則需要查找到發(fā)布狀態(tài)為"線上測試"的定義信息,也就是查 找處于線上測試狀態(tài)的第二定義信息。而如果查找不到線上測試狀態(tài)的定義信息,則查找 發(fā)布狀態(tài)為"已發(fā)布"的定義信息,也就是查找發(fā)布狀態(tài)為"已發(fā)布"狀態(tài)的Web API初始 版本的第一定義信息。
[0051] 而如果所述請求是在線上正式環(huán)境中處理的,在所述數(shù)據(jù)庫中查找發(fā)布狀態(tài)為已 發(fā)布狀態(tài)的所述Web API的定義信息。由于調(diào)用請求是在線上正式環(huán)境中發(fā)起的,就需要 查找發(fā)布狀態(tài)為"已發(fā)布"狀態(tài)的所述Web API的定義信息,由于此時處于升級線上測試階 段,Web API的升級版本還未正式發(fā)布,因此,可以查找發(fā)布狀態(tài)為已發(fā)布狀態(tài)的第一定義 信息,即Web API的初始版本的定義信息,這樣就實(shí)現(xiàn)了線上測試環(huán)境和線上正式環(huán)境的隔 離。
[0052] 而在兼容性升級的升級發(fā)布階段,Web API的第二定義信息中的發(fā)布狀態(tài)被更新 為"已發(fā)布",第一定義信息的狀態(tài)被更新為"已過期",當(dāng)接收到調(diào)用所述Web API的請求 時,如果所述請求是在線上正式環(huán)境中處理的,就需要查找發(fā)布狀態(tài)為"已發(fā)布"的定義信 息,由于Web API的升級版本已發(fā)布,而所述Web API的初始版本已過期,因此可以查找到 發(fā)布狀態(tài)為已發(fā)布的第二定義信息。這樣,線上正式環(huán)境采用的Web API在發(fā)布后就自動 從初始版本切換為升級版本,實(shí)現(xiàn)了兼容性升級對外部應(yīng)用的透明性,外部應(yīng)用不需要對 調(diào)用請求做任何變更,就能得到兼容性升級后的Web API的處理結(jié)果??蛇x地,同時還可以 將主版本號和子版本號包含在返回的結(jié)果里,可以使外部應(yīng)用知道每次的返回結(jié)果是由哪 個具體版本的Web API處理的,當(dāng)對返回結(jié)果有疑惑時,便于快速排查問題。
[0053] 由上所述,在兼容性升級中,由于Web API在升級前后的主版本號沒有改變,因此, 在外部應(yīng)用調(diào)用所述Web API時,不需要改變調(diào)用方式就可以得到升級之后的Web API的 處理結(jié)果,而當(dāng)處理所述調(diào)用請求時,(例如,網(wǎng)關(guān)處理外部應(yīng)用對所述Web API的調(diào)用請 求)又能區(qū)分升級前和升級后的Web API版本,并將各自路由到不同的目標(biāo)系統(tǒng)。同時,根 據(jù)Web API的發(fā)布狀態(tài)有效的將線上測試環(huán)境和線上正式環(huán)境進(jìn)行了隔離。
[0054] 在非兼容性升級的升級線上測試階段,所述Web API第一定義信息中發(fā)布狀態(tài)為 "已發(fā)布"狀態(tài),第二定義信息中的發(fā)布狀態(tài)為"線上測試"狀態(tài)。如果所述調(diào)用請求是在線 上測試環(huán)境中處理的,需要查找發(fā)布狀態(tài)為線上測試狀態(tài)的定義信息,如果查找不到發(fā)布 狀態(tài)為線上測試狀態(tài)的定義信息,則查找發(fā)布狀態(tài)為已發(fā)布狀態(tài)的定義信息。當(dāng)接收到外 部應(yīng)用對所述Web API的調(diào)用請求時,如果外部應(yīng)用仍然以之前調(diào)用所述Web API的初始 版本的方式發(fā)起調(diào)用請求(例如,調(diào)用名稱為abc. defg. hi j,主版本號1. 0的Web API ),則 根據(jù)請求中的調(diào)用信息(所述調(diào)用信息至少包括:所調(diào)用的Web API的名稱、主版本號),要 查找名稱為abc. defg. hi j,主版本號1. 0的定義信息。而當(dāng)外部請求想要調(diào)用升級之后的 Web API的升級版本時,由于非兼容性升級中,Web API升級前后的初始版本和升級版本的 主版本號不同,因此,則在調(diào)用升級之后的Web API升級版本時,需要改變調(diào)用參數(shù)中的主 版本號,例如,原來的主版本號為1. 〇,升級后主版本號為2. 0,則外部應(yīng)用如果想要調(diào)用升 級之后的Web API升級版本,在調(diào)用之時,需要改變調(diào)用請求中的主版本號為2.0,而在接 收到外部應(yīng)用的調(diào)用請求時,根據(jù)請求中的調(diào)用信息,查找名稱為abc. defg. hij,主版本號 2.0的定義信息。
[0055] 而如果所述請求是在線上正式環(huán)境中處理的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請 求中的調(diào)用信息相對應(yīng)的、發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信息。例如,當(dāng)接 收到外部應(yīng)用對所述Web API的調(diào)用請求時,如果外部應(yīng)用仍然以之前調(diào)用所述Web API 的初始版本的方式發(fā)起調(diào)用請求時,例如,調(diào)用名稱為abc. defg. hij,主版本號1. 0的Web API,則根據(jù)請求中的調(diào)用信息(所述調(diào)用信息至少包括:所調(diào)用的Web API的名稱、主版本 號),要查找名稱為abc. defg. hi j,主版本號1. 0的定義信息。而如果外部應(yīng)用的調(diào)用請求 想要調(diào)用升級之后的Web API的升級版本,由于非兼容性升級中,Web API升級前后的初始 版本和升級版本的主版本號不同,因此需要改變調(diào)用參數(shù)中的主版本號,例如,原來的主版 本號為1. 〇,升級后主版本號為2. 0,則外部應(yīng)用在調(diào)用升級版本時,需要改變調(diào)用請求中 的主版本號為2.0,而在接收到外部應(yīng)用的調(diào)用請求時,根據(jù)請求中的調(diào)用信息,查找名稱 為abc. defg. hi j,主版本號2. 0,處于已發(fā)布狀態(tài)的定義信息,由于此時數(shù)據(jù)庫中主版本號 為2. 0的定義信息的發(fā)布狀態(tài)還為線上測試狀態(tài),因此會查找不到主版本號為2. 0,處于已 發(fā)布狀態(tài)的定義信息,這時,就會導(dǎo)致線上正式環(huán)境中的調(diào)用失敗,這樣就實(shí)現(xiàn)了線上測試 環(huán)境和線上正式環(huán)境的隔離。
[0056] 在非兼容性升級的升級發(fā)布階段,當(dāng)接收到外部應(yīng)用對所述Web API的調(diào)用請求 時,由于Web API升級前后的初始版本和升級版本的主版本號不同,例如原來的版本(所述 Web API的初始版本)號為1.0,非兼容性升級之后的版本(所述Web API的升級版本)號為 2. 0,如果外部應(yīng)用仍然以之前調(diào)用所述Web API的初始版本的方式發(fā)起調(diào)用請求時,例如, 調(diào)用名稱為abc. defg. hi j,主版本號1. 0的Web API,則要根據(jù)請求中的調(diào)用信息,查找名 稱為abc. defg. hi j,主版本號1. 0,處于已發(fā)布狀態(tài)的定義信息;而如果外部請求想要調(diào)用 升級之后的Web API的升級版本,則外部應(yīng)用需要改變調(diào)用參數(shù)中的主版本號,例如,原來 的主版本號為1. 0,升級后主版本號為2. 0,則外部應(yīng)用在調(diào)用升級版本時,需要改變調(diào)用 請求中的主版本號為2.0,而在接收到外部應(yīng)用的調(diào)用請求時,根據(jù)請求中的調(diào)用信息,查 找名稱為abc. defg. hi j,主版本號2. 0,處于已發(fā)布狀態(tài)的定義信息。
[0057] 由上所述,在非兼容性升級中,由于Web API升級前后的主版本號不同,因此在調(diào) 用所述Web API時,外部應(yīng)用可以自行選擇調(diào)用升級之前的Web API初始版本還是調(diào)用升 級之后的所述Web API的升級版本,這樣在進(jìn)行Web API的非兼容性升級的同時,又不影響 已有應(yīng)用的運(yùn)行。同時,根據(jù)Web API的發(fā)布狀態(tài)有效的將線上測試環(huán)境和線上正式環(huán)境 進(jìn)行了隔離。
[0058] 在步驟S402中,基于查找到的定義信息確定目標(biāo)系統(tǒng)。
[0059] 在步驟S403中,將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng)對所述 請求進(jìn)行處理。
[0060] 在步驟S404中,接收來自目標(biāo)系統(tǒng)對所述請求的處理結(jié)果。
[0061] 例如,當(dāng)網(wǎng)關(guān)接收到外部應(yīng)用的調(diào)用請求時,對所述請求進(jìn)行處理,可參考圖5,是 對外部應(yīng)用的調(diào)用請求進(jìn)行處理的處理流程的示意圖;如圖5所示:
[0062] 外部應(yīng)用50訪問網(wǎng)關(guān)10,對名稱為N且主版本=V的Web API發(fā)起調(diào)用請求。
[0063] 步驟S1,網(wǎng)關(guān)10接收到外部應(yīng)用50的調(diào)用請求后,如果所述調(diào)用請求是基于線上 線上測試環(huán)境的調(diào)用請求,則從數(shù)據(jù)庫中查找名稱為N、主版本號為V且發(fā)布狀態(tài)為"線上 測試"的Web API定義信息,如果不存在,則再查詢狀態(tài)為已發(fā)布的Web API定義信息。如 果所述調(diào)用請求是基于線上正式環(huán)境的,則從數(shù)據(jù)庫中查詢名稱為N、主版本=V且發(fā)布狀 態(tài)為已發(fā)布的Web API定義信息。
[0064] 步驟S2,網(wǎng)關(guān)10根據(jù)查找到的Web API定義信息中的路由信息,確定對應(yīng)的目標(biāo) 前置系統(tǒng)30,其中,目標(biāo)前置系統(tǒng)是一組業(yè)務(wù)相似的目標(biāo)系統(tǒng)的前置系統(tǒng),它為這組目標(biāo)系 統(tǒng)提供一個統(tǒng)一的外部調(diào)用接口給網(wǎng)關(guān)。
[0065] 步驟S3,網(wǎng)關(guān)將所述調(diào)用請求向目標(biāo)前置系統(tǒng)20轉(zhuǎn)發(fā)。
[0066] 步驟S4,目標(biāo)前置系統(tǒng)20根據(jù)Web API定義信息中的名稱、主版本號、子版本號確 定處理本次請求的目標(biāo)系統(tǒng)30,其中,目標(biāo)系統(tǒng)是最終處理請求的業(yè)務(wù)系統(tǒng)。
[0067] 步驟S5,目標(biāo)前置系統(tǒng)20將請求轉(zhuǎn)發(fā)給目標(biāo)系統(tǒng)30。
[0068] 步驟S6,目標(biāo)系統(tǒng)30處理請求。
[0069] 步驟S7,目標(biāo)系統(tǒng)30將處理結(jié)果返回給目標(biāo)前置系統(tǒng)20
[0070] 步驟S8,目標(biāo)前置系統(tǒng)20將結(jié)果返回給網(wǎng)關(guān)10。
[0071] 步驟S9,網(wǎng)關(guān)10將結(jié)果返回給外部應(yīng)用50。
[0072] 參考圖6,為本申請涉及的一種網(wǎng)絡(luò)應(yīng)用程序接口升級的系統(tǒng)的框圖,如圖6所 示,該網(wǎng)絡(luò)應(yīng)用程序接口升級的系統(tǒng)600包括:信息生成模塊601以及信息更新模塊602。
[0073] 信息生成模塊601,可以用于在對所述Web API進(jìn)行升級的升級啟動階段,生成與 升級后得到所述Web API的升級版本相對應(yīng)的第二定義信息,其中,所述第二定義信息被存 儲在數(shù)據(jù)庫中,所述數(shù)據(jù)庫中還存儲與所述Web API的初始版本向?qū)?yīng)的第一定義信息,并 且其中,所述第一和第二定義信息分別至少包括:Web API的名稱、主版本號、子版本號、發(fā) 布狀態(tài)信息以及路由信息。
[0074] 信息更新模塊602,可以用于在對所述Web API的升級版本進(jìn)行線上測試的升級 線上測試階段,更新所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng) 前的發(fā)布狀態(tài)為線上測試狀態(tài);以及用于在對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā) 布階段,更新所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā) 布狀態(tài)為已發(fā)布狀態(tài)。并且其中,如果所述Web API的升級類型為兼容性升級,所述信息更 新模塊602還可以用于在所述升級發(fā)布階段,更新所述第一定義信息中的發(fā)布狀態(tài)信息以 標(biāo)記所述Web API的初始版本為已過期。
[0075] 所述信息生成模塊601還可以用于:當(dāng)所述Web API的升級類型為兼容性升級時, 將所述第二定義信息中的主版本號生成為與所述第一定義信息中相同的主版本號,將所述 第二定義信息中的子版本號生成為所述第一定義信息中的子版本號不同的子版本號。
[0076] 當(dāng)所述Web API的升級類型為非兼容性升級時,將所述第二定義信息中的主版本 號生成為所述第一定義信息中的主版本號不同的主版本號,將所述第二定義信息中的子版 本號生成為與所述第一定義信息中相同的子版本號。
[0077] 所述系統(tǒng)還可以包括信息查找模塊603,該模塊可以用于當(dāng)接收到對所述Web API 的調(diào)用請求時,如果所述請求是線上測試環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中 的調(diào)用信息相對應(yīng)的且發(fā)布狀態(tài)為線上測試狀態(tài)的所述Web API的定義信息,如果查找不 至IJ,則在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài) 的所述Web API的定義信息;如果所述請求是線上正式環(huán)境的,在所述數(shù)據(jù)庫中查找與所 述調(diào)用請求相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信息。
[0078] 其中,所述調(diào)用信息至少包括:所調(diào)用的Web API的名稱、主版本號。
[0079] 所述系統(tǒng)還可以包括:確定模塊604、轉(zhuǎn)發(fā)模塊605、以及接收模塊606。
[0080] 確定模塊604,可以用于基于查找到的定義信息確定目標(biāo)系統(tǒng)。
[0081] 轉(zhuǎn)發(fā)模塊605,可以用于將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng) 對所述請求進(jìn)行處理。
[0082] 接收模塊606,可以用于接收來自目標(biāo)系統(tǒng)對所述請求的處理結(jié)果。
[0083] 本申請的方法的具體實(shí)施與系統(tǒng)600所包括的各個模塊的具體實(shí)施是相對應(yīng)的, 可以相互參照,為了不模糊本申請,在此省略對系統(tǒng)600的具體細(xì)節(jié)進(jìn)行描述。
[0084] 應(yīng)當(dāng)注意,盡管在上文描述中提及了系統(tǒng)的若干模塊或子模塊,但是這種劃分并 非強(qiáng)制性的。實(shí)際上,根據(jù)本申請的實(shí)施方式,上文描述的兩個或更多模塊的特征和功能可 以在一個模塊中具體化。反之,上文描述的一個模塊的特征和功能可以進(jìn)一步劃分為由多 個模塊來具體化。
[0085] 此外,盡管在附圖中以特定順序描述了本申請方法的操作,但是,這并非要求或者 暗示必須按照該特定順序來執(zhí)行這些操作,或是必須執(zhí)行全部所示的操作才能實(shí)現(xiàn)期望的 結(jié)果。
[0086] 本申請可以在由計算機(jī)執(zhí)行的計算機(jī)可執(zhí)行指令的一般上下文中描述,例如程序 模塊或單元。一般地,程序模塊或單元可以包括執(zhí)行特定任務(wù)或?qū)崿F(xiàn)特定抽象數(shù)據(jù)類型的 例程、程序、對象、組件、數(shù)據(jù)結(jié)構(gòu)等等。一般來說,程序模塊或單元可以由軟件、硬件或兩者 的結(jié)合來實(shí)現(xiàn)。也可以在分布式計算環(huán)境中實(shí)踐本申請,在這些分布式計算環(huán)境中,由通過 通信網(wǎng)絡(luò)而被連接的遠(yuǎn)程處理設(shè)備來執(zhí)行任務(wù)。在分布式計算環(huán)境中,程序模塊或單元可 以位于包括存儲設(shè)備在內(nèi)的本地和遠(yuǎn)程計算機(jī)存儲介質(zhì)中。
[0087] 在一個典型的配置中,計算設(shè)備包括一個或多個處理器(CPU)、輸入/輸出接口、 網(wǎng)絡(luò)接口和內(nèi)存。
[0088] 內(nèi)存可能包括計算機(jī)可讀介質(zhì)中的非永久性存儲器,隨機(jī)存取存儲器(RAM)和/ 或非易失性內(nèi)存等形式,如只讀存儲器(ROM)或閃存(flash RAM)。內(nèi)存是計算機(jī)可讀介質(zhì) 的示例。
[0089] 計算機(jī)可讀介質(zhì)包括永久性和非永久性、可移動和非可移動媒體可以由任何方法 或技術(shù)來實(shí)現(xiàn)信息存儲。信息可以是計算機(jī)可讀指令、數(shù)據(jù)結(jié)構(gòu)、程序的模塊或其他數(shù)據(jù)。 計算機(jī)的存儲介質(zhì)的例子包括,但不限于相變內(nèi)存(PRAM)、靜態(tài)隨機(jī)存取存儲器(SRAM)、 動態(tài)隨機(jī)存取存儲器(DRAM)、其他類型的隨機(jī)存取存儲器(RAM)、只讀存儲器(ROM)、電 可擦除可編程只讀存儲器(EEPR0M)、快閃記憶體或其他內(nèi)存技術(shù)、只讀光盤只讀存儲器 (CD-ROM)、數(shù)字多功能光盤(DVD)或其他光學(xué)存儲、磁盒式磁帶,磁帶磁磁盤存儲或其他磁 性存儲設(shè)備或任何其他非傳輸介質(zhì),可用于存儲可以被計算設(shè)備訪問的信息。按照本文中 的界定,計算機(jī)可讀介質(zhì)不包括非暫存電腦可讀媒體(transitory media),如調(diào)制的數(shù)據(jù) 信號和載波。
[0090] 還需要說明的是,術(shù)語"包括"、"包含"或者其任何其他變體意在涵蓋非排他性的 包含,從而使得包括一系列要素的過程、方法、商品或者設(shè)備不僅包括那些要素,而且還包 括沒有明確列出的其他要素,或者是還包括為這種過程、方法、商品或者設(shè)備所固有的要 素。在沒有更多限制的情況下,由語句"包括一個……"限定的要素,并不排除在包括所述 要素的過程、方法、商品或者設(shè)備中還存在另外的相同要素。
[0091] 本領(lǐng)域內(nèi)的技術(shù)人員應(yīng)明白,本申請的實(shí)施例可提供為方法、系統(tǒng)、或計算機(jī)程序 產(chǎn)品。因此,本申請可采用完全硬件實(shí)施例、完全軟件實(shí)施例、或結(jié)合軟件和硬件方面的實(shí) 施例的形式。而且,本申請可采用在一個或多個其中包含有計算機(jī)可用程序代碼的計算機(jī) 可用存儲介質(zhì)(包括但不限于磁盤存儲器、CD-ROM、光學(xué)存儲器等)上實(shí)施的計算機(jī)程序產(chǎn) 品的形式。
[0092] 本文中應(yīng)用了具體個例對本申請的原理及實(shí)施方式進(jìn)行了闡述,以上實(shí)施例的說 明只是用于幫助理解本申請的方法及其主要思想;同時,對于本領(lǐng)域的一般技術(shù)人員,依據(jù) 本申請的思想,在【具體實(shí)施方式】及應(yīng)用范圍上均會有改變之處,綜上所述,本說明書內(nèi)容不 應(yīng)理解為對本申請的限制。
【權(quán)利要求】
1. 一種網(wǎng)絡(luò)應(yīng)用程序接口(Web API)升級的方法,其特征在于,包括: 在對Web API進(jìn)行升級的升級啟動階段,生成與所述Web API的升級版本相對應(yīng)的第 二定義信息,其中,所述第二定義信息被存儲在數(shù)據(jù)庫中,所述數(shù)據(jù)庫中還存儲與所述Web API的初始版本相對應(yīng)的第一定義信息,并且其中,所述第一和第二定義信息分別至少包 括:Web API的名稱、主版本號、子版本號、發(fā)布狀態(tài)信息以及路由信息; 在對所述Web API的升級版本進(jìn)行線上測試的升級線上測試階段,更新所述第二定義 信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為線上測試狀態(tài); 在對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,更新所述第二定義信息中的 發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為已發(fā)布狀態(tài),并且其中,如果 所述Web API的升級類型為兼容性升級,則在所述升級發(fā)布階段,更新所述第一定義信息中 的發(fā)布狀態(tài)信息以標(biāo)記所述Web API的初始版本為已過期。
2. 根據(jù)權(quán)利要求1所述的方法,其特征在于,如果所述Web API的升級類型為兼容性升 級,則將所述第二定義信息中的主版本號生成為與所述第一定義信息中相同的主版本號, 將所述第二定義信息中的子版本號生成為與所述第一定義信息中的子版本號不同的子版 本號; 如果所述Web API的升級類型為非兼容性升級,則將所述第二定義信息中的主版本號 生成為與所述第一定義信息中的主版本號不同的主版本號,將所述第二定義信息中的子版 本號生成為與所述第一定義信息中相同的子版本號。
3. 根據(jù)權(quán)利要求1所述的方法,其特征在于,當(dāng)接收到對所述Web API的調(diào)用請求時, 如果所述請求是線上測試環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息 相對應(yīng)且發(fā)布狀態(tài)為線上測試狀態(tài)的所述Web API的定義信息,如果查找不到,則在所述數(shù) 據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API 的定義信息; 如果所述請求是線上正式環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息 相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信息; 其中,所述調(diào)用信息至少包括:所調(diào)用Web API的名稱、主版本號。
4. 根據(jù)權(quán)利要求3所述的方法,其特征在于,還包括: 基于查找到的定義信息確定處理所述調(diào)用請求的目標(biāo)系統(tǒng); 將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng)對所述請求進(jìn)行處理; 接收來自目標(biāo)系統(tǒng)對所述請求的處理結(jié)果。
5. -種網(wǎng)絡(luò)應(yīng)用程序接口(Web API)升級的系統(tǒng),其特征在于,包括: 信息生成模塊,用于在對Web API進(jìn)行升級的升級啟動階段,生成與升級后得到所述 Web API的升級版本相對應(yīng)的第二定義信息,其中,所述第二定義信息被存儲在數(shù)據(jù)庫中, 所述數(shù)據(jù)庫中還存儲與所述Web API的初始版本相對應(yīng)的第一定義信息,并且其中,所述第 一和第二定義信息分別至少包括:Web API的名稱、主版本號、子版本號、發(fā)布狀態(tài)信息以及 路由信息; 信息更新模塊,用于在對所述Web API的升級版本進(jìn)行線上測試的升級線上測試階段, 更新所述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為 線上測試狀態(tài);以及用于在對所述Web API的升級版本進(jìn)行發(fā)布的升級發(fā)布階段,更新所 述第二定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API升級版本當(dāng)前的發(fā)布狀態(tài)為已發(fā)布 狀態(tài),并且其中,如果所述Web API的升級類型為兼容性升級,所述信息更新模塊還用于在 所述升級發(fā)布階段,更新所述第一定義信息中的發(fā)布狀態(tài)信息以標(biāo)記所述Web API的初始 版本為已過期。
6. 根據(jù)權(quán)利要求5所述的系統(tǒng),其特征在于,所述信息生成模塊還用于:當(dāng)所述Web API的升級類型為兼容性升級時,將所述第二定義信息中的主版本號生成為與所述第一定 義信息中相同的主版本號,將所述第二定義信息中的子版本號生成為與所述第一定義信息 中的子版本號不同的子版本號; 當(dāng)所述Web API的升級類型為非兼容性升級時,將所述第二定義信息中的主版本號生 成為與所述第一定義信息中的主版本號不同的主版本號,將所述第二定義信息中的子版本 號生成為與所述第一定義信息中相同的子版本號。
7. 根據(jù)權(quán)利要求5所述的系統(tǒng),其特征在于,還包括:信息查找模塊, 用于當(dāng)接收到對所述Web API的調(diào)用請求時, 如果所述請求是線上測試環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息 相對應(yīng)且發(fā)布狀態(tài)為線上測試狀態(tài)的所述Web API的定義信息,如果查找不到,則在所述數(shù) 據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API 的定義信息; 如果所述請求是線上正式環(huán)境的,在所述數(shù)據(jù)庫中查找與所述調(diào)用請求中的調(diào)用信息 相對應(yīng)且發(fā)布狀態(tài)為已發(fā)布狀態(tài)的所述Web API的定義信息; 其中,所述調(diào)用信息至少包括:所調(diào)用Web API的名稱、主版本號。
8. 根據(jù)權(quán)利要求7所述的系統(tǒng),其特征在于,還包括: 確定模塊,用于基于查找到的定義信息確定目標(biāo)系統(tǒng); 轉(zhuǎn)發(fā)模塊,用于將所述調(diào)用請求向所述目標(biāo)系統(tǒng)轉(zhuǎn)發(fā),以使所述目標(biāo)系統(tǒng)對所述請求 進(jìn)行處理; 接收模塊,用于接收來自目標(biāo)系統(tǒng)對所述請求的處理結(jié)果。
【文檔編號】G06F9/445GK104216724SQ201310217643
【公開日】2014年12月17日 申請日期:2013年6月3日 優(yōu)先權(quán)日:2013年6月3日
【發(fā)明者】張先武 申請人:阿里巴巴集團(tuán)控股有限公司
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點(diǎn)贊!
1
苗栗县| 宜宾县| 博乐市| 澎湖县| 高邮市| 商都县| 福州市| 黄冈市| 新郑市| 黄浦区| 青铜峡市| 钟山县| 台前县| 吴忠市| 铅山县| 金湖县| 舟曲县| 即墨市| 文安县| 东辽县| 山东省| 壤塘县| 嵩明县| 岳池县| 五常市| 石阡县| 汝南县| 墨竹工卡县| 仪陇县| 南和县| 乌拉特中旗| 玛多县| 岑溪市| 云梦县| 巴彦县| 电白县| 醴陵市| 马关县| 龙里县| 大方县| 靖宇县|