【原】關於介面規範的重要性

来源:https://www.cnblogs.com/zdd-java/archive/2018/03/20/8612763.html
-Advertisement-
Play Games

前言:單體項目拆分為SOA分散式架構後,關於介面層的定義規範尤其重要。今天就總結一下關於一次不規範的定義介面導致的問題。 #首先我目前從事的項目架構大致是下圖這樣的: 主技術棧:dubbo+spring boot;其中我們內部的wap、app、pc都有相似的業務,例如user-service。 #出 ...


 

    前言:單體項目拆分為SOA分散式架構後,關於介面層的定義規範尤其重要。今天就總結一下關於一次不規範的定義介面導致的問題。

  #首先我目前從事的項目架構大致是下圖這樣的:

         主技術棧:dubbo+spring boot;其中我們內部的wap、app、pc都有相似的業務,例如user-service。

    

  

    #出現問題起源

      產品給了一個比較急的需求,是關於以前一個校驗漏洞的修複,經過代碼查閱,我定義的介面是:

      int queryUserIsOpen(String cardId);

      於是我進行改造後如下:

      Result queryUserIsOpen(String cardid,int userType);

      在PC端測試OK後直接丟上生產;結果第二天收到反應wap端和app端某業務出現異常,進行日誌排查發現報錯是返回類型有誤。後來才想起其他端也有調用這個方法,由於我改了介面返回的參數類型,然後又發佈到了線上,那麼之前的服務已經被我的版本覆蓋,這時候其他端還是用的舊的代碼,一旦它們那邊遠程調用後由於返回的實際是Result,但它們還是用 int去接收。

     於是我先讓wap和app升級我改的版本,然後同步兩邊代碼後再發到生產以此解決這個問題。

   #為什麼SOA架構會普遍存在這個問題:

  庫的版本維護與業務線之間代碼的耦合:

  業務線A將user.so由版本1升級至版本2,如果不相容業務線B的代碼,會導致B業務出現問題;

      業務線A如果通知了業務線B升級,則是的業務線B會無故做一些“自身業務無關”的升級,非常鬱悶。當然,如果各個業務線都是拷貝了一份代碼則不存在這個問題。

 

   #如何避免這個問題

   很早之前就有看過介面規範的必要性,但有時候大意了忽略了其他部門負責的也共同調用了這個服務。通過上面的例子不難發現其實一開始只要定義好介面的規範就可以避免這個問題。如剛開始就定義好返回的bean為Result,入參統一為Vo,那麼當我下游出現變動,由於返回的結果已經顯示規定好了為Result,那麼就避免了剛開始我在文中遇到的那個問題,減少線上維護的成本。

  Result代碼如下:

  

public class Result<T> implements Serializable {

    private static final long serialVersionUID = 1L;

    /** 返回代碼 */
    private String code = "200";

    /** 返回錯誤消息提示 */
    private String message;

    /** 如果需要驗簽則返回請求過來的token */
    private String token;

    /** 返回客戶端的簽名 */
    private String sign;

    /** 返回結果 */
    private T t;

    public Result() {
        super();
    }

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、SpringData入門 在上次學SpringBoot的時候,那時候的教程就已經涉及到了一點SpringData JPA的知識了。當時還是第一次見,覺得也沒什麼大不了,就是封裝了Hibernate的API而已。 然後在慕課網上又看到了SpringData的教程了。於是就進去學習了一番。 教程地址 ...
  • 一、實體基本映射 二、實體表間映射 1、一對一實體映射:人與地址 2、一對多實體映射:員工表與部門表 3、多對多實體映射:老師與學生 ...
  • 1,首字母大寫 2,replace,替換 查幫助 如果是面向過程的函數用法,直接help( 函數名 ),如help( abs ) 用法說明: replace(...) S.replace(old, new[, count]) -> string Return a copy of string S w ...
  • Description 有n位同學,每位同學都參加了全部的m門課程的期末考試,都在焦急的等待成績的公佈。第i位同學希望在第ti天 或之前得知所.有.課程的成績。如果在第ti天,有至少一門課程的成績沒有公佈,他就會等待最後公佈成績的課程 公佈成績,每等待一天就會產生C不愉快度。對於第i門課程,按照原本 ...
  • 基本概念 問題空間:問題空間是問題解決者對一個問題所達到的全部認識狀態,它是由問題解決者利用問題所包含的信息和已貯存的信息主動的地構成的。 初始狀態:一開始時的不完全的信息或令人不滿意的狀況; 目標狀態:你希望獲得的信息或狀態; 操作:為了從初始狀態邁向目標狀態,你可能採取的步驟。 對象:對象(ob ...
  • 操作系統 : CentOS7.3.1611_x64 gcc版本 :4.8.5 Python 版本 : 2.7.5 思路如下 : 1、將浮點數a通過記憶體拷貝,賦值給相同位元組的整型數據b; 2、將b轉換為網路位元組序變數c併發送到服務端; 3、服務端接收c並將c轉換為主機位元組序變數d; 4、將整型數據d通 ...
  • 一、.py文件可以看做一個模塊,模塊類似其他語言中封裝的類庫 模塊分類: 內置模塊 自定義模塊 第三方模塊(需要安裝才能使用) 我想要使用cal.py中定義的函數,可以這樣做 cal.py源代碼: import_test.py要使用add函數: 二,內置屬性__name__ cal.py 當執行ca ...
  • 一樣,咱的電腦還是得先擁有Python,並且安裝了Numpy庫。有疑問的話可以看這裡呦~~~~ 下麵開講: NumPy的主要對象是齊次多維數組。它是一個元素表(通常是數字),並且都是相同類型,由正整數的元組索引。 其他暫且略過,咱主要說一些可以聽懂的並且有實際效用的。 首先,我們得創建有一個nda ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...