讀發佈!設計與部署穩定的分散式系統(第2版)筆記31_版本問題

来源:https://www.cnblogs.com/lying7/archive/2023/08/14/17625907.html
-Advertisement-
Play Games

![](https://img2023.cnblogs.com/blog/3076680/202308/3076680-20230812234533249-1035884507.png) # 1. 在軟體與外部環境之間的許多交匯點上,版本控制基本上處於混亂狀態 ## 1.1. 不應該為了更新自身系統 ...


1. 在軟體與外部環境之間的許多交匯點上,版本控制基本上處於混亂狀態

1.1. 不應該為了更新自身系統的API,而讓服務消費者被迫與你同時發佈新版本

1.2. 多數服務新版本的發佈應該具有相容性

2. 分層的“約定”棧

2.1. 連接握手和持續時間

2.2. 請求組幀

2.3. 內容編碼

2.4. 消息語法

2.5. 消息語義

2.6. 鑒權和身份驗證

3. 對請求要協變

3.1. covariant request

4. 對響應要逆變

4.1. contravariant response

5. 即

5.1. 可以比以往提出的要求更少

5.2. 可以比以往接受的可選信息更多

5.3. 可以比以往返回的響應更多

5.4. 可以類比必填參數和可選參數

6. 安全的變更

6.1. 在參數上強制執行以前所需約束的子集

6.2. 返回以前可返回值的超集

6.3. 接受以前可以接受的參數的超集

6.4. 要求必須填寫以前必填參數的一個子集

7. 生成式測試技術

8. 破壞API的變更

8.1. 減少API破壞性變更影響的第一個先決條件是在請求和回覆消息格式中添加一個版本號欄位

8.2. 為URL添加版本辨別欄位,可以用首碼形式或查詢參數來實現

8.2.1. 同一實體的不同表示看起來像是不同的資源,而這在REST世界中是禁忌

8.3. 使用PUT和POST上的Content-Type標頭指示正在發送的版本

8.3.1. 可以為版本定義一個媒體類型application/vnd.lendzit.loan-request.v1和一個新的媒體類型application/vnd.lendzit.loan-request.v2

8.3.2. 優點

8.3.2.1. 在資料庫中存儲的所有URL都可以繼續工作,客戶端無須更改路由就可升級

8.3.3. 缺點

8.3.3.1. 單單憑藉URL已經不夠區分版本了,像application/json和text/xml這樣的通用媒體類型根本提供不了任何幫助

8.3.3.2. 客戶端必須事先知道存在這種特殊的媒體類型,以及所有允許的媒體類型

8.3.3.3. 一些框架雖然支持基於媒體類型的路由,但配置起來會有難度

8.4. 僅針對PUT和POST,在請求正文中添加一個欄位來指示預期版本

8.4.1. 優點是不需要路由,易於實施

8.4.2. 缺點是無法涵蓋所需要的所有場景

8.5. 使用特定於應用程式的自定義標頭指示所需的版本

8.5.1. 可以定義一個類似api-version的標頭

8.5.2. 優點是具有完全的靈活性,並且與媒體類型和URL正交

8.5.3. 缺點

8.5.3.1. 要為特定框架編寫路由處理器

8.5.3.2. 這個標頭是另一個必須與服務消費者分享的秘密

8.6. 服務提供方都必須在一段時間內同時支持舊版本和新版本

8.7. 如果要在一些URL中添加版本信息,那麼務必同時在所有路由中都添加這個版本

8.7.1. 即使這次變更只涉及一個路由,也不要強制用戶記住哪些版本號對應哪些API

8.8. 只要不影響未來進行的變更,儘可能地減少代碼重覆

9. 處理其他系統的版本問題

9.1. 軟體應該保持杞人憂天的狀態

9.2. 雖然請求規範中添加了一些新欄位,但並不意味著所有人都會遵守新規範

9.3. 請求端與響應端檢查自己是否符合規範

9.4. 將測試分為不同的部分,有助於隔離通信中的故障,並能使代碼更加穩健

9.4.1. 我們不會再對另一方的行為做出不合理的假設


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [toc] ### 1.晶元手冊中的LED電路圖 ![圖1](https://img-blog.csdnimg.cn/34c2a95aa89c4cbe8a7904429d889564.png) ### 2.官網手冊 ![圖2](https://img-blog.csdnimg.cn/e9b1131d ...
  • 設計字元設備 文件系統調用系統IO的內核處理過程 在Linux文件系統管理中,當應用程式調用open函數時,內核會根據文件路徑找到文件的索引結點(inode),為文件分配文件描述符和文件對象,並根據打開模式和許可權等參數進行相應的操作和設置。 硬體層原理 思路:把底層寄存器配置操作放在文件操作介面里, ...
  • 前面講了Centos如何安裝telnet遠程,這次分享Ubuntu系統如何安裝遠程telnet,作為咱們運維備用遠程途徑 一、下載和安裝 查看系統版本:Ubuntu 22.04.1 LTS 線上安裝: apt install telnet telnetd openbsd-inetd 離線安裝: 離線 ...
  • > 拋磚引玉:多個查詢需要在同一時刻進行數據的修改,就會產生併發控制的問題。我們需要如何避免寫個問題從而保證我們的資料庫數據不會被破壞。 ## 鎖的概念 讀鎖是共用的互相不阻塞的。多個事務在聽一時刻可以同時讀取同一資源,而相互不幹擾。 寫鎖的排他的。一個寫鎖會阻塞其他寫鎖或讀鎖。出於安全考慮只有這樣 ...
  • CentOS 7.9 環境的安裝不再贅述,不清楚可以參看之前的文章:https://www.cnblogs.com/iflytek/p/14403664.html 1、準備GBase 8a的安裝包:GBase8a-NoLicense-Free-8.6.2_build43-R7-redhat7.3-x ...
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
  • 最近翻到 ElementUI 的日期組件源碼,看到一些處理日期的工具方法,挺有意思,平常沒有註意到,特此記錄下來。 ### 獲取當前日期的前一天,後一天 ```js export const prevDate = function(date, amount = 1) { return new Dat ...
  • 在現代的 Web 開發中,表單是不可或缺的組件之一。用戶可以通過表單輸入和提交數據,而開發者則需要對這些數據進行處理和存儲。然而,在某些情況下,我們可能需要重置表單並恢復到最初的狀態。 本文介紹瞭如何使用 form 表單處理庫來實現表單恢復初始數據的功能。通過 form 提供的靈活性和方便性,我們... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...