AppBoxFuture: 服務模型的在線調試與性能監測

  • 2019 年 10 月 24 日
  • 筆記

  框架內的服務模型(ServiceModel)用於處理各類業務邏輯(如最簡單的CRUD操作),在設計時以類似於偽程式碼的形式存在,發布時後端會通過Roslyn轉換並編譯為運行時程式碼。為了方便開發者作者初步實現了在線調試服務與監測服務調用性能的功能,下面分別介紹。

一、服務在線調試

1.1 實現原理

  原本想參照VSCode實現調試功能,但VSCode使用的vsdbg調試器有許可限制,無法用於第三方IDE,好在GitHub上的netcoredbg項目使用MIT許可且支援VSCode的調試協議。作者畫了個流程圖簡要說明一下調試流程:

  1. WebIDE定位需要調試的服務方法並設置相應的斷點後啟動調試(如果方法有參數則需要輸入參數值);
  2. 服務端DebugService收到調試請求後轉換並編譯Debug版本的服務程式碼,然後啟動netcoredbg子進程(需要重定向標準輸入輸出,netcoredbg通過標準輸入輸出接收調試指令並響應),初始化調試子進程後發送運行命令啟動AppContainer子進程,AppContainer子進程在啟動時載入已編譯好的目標服務實例並注入容器內;
  3. 服務端DebugService在一切準備就緒後發送調用服務方法(調試目標)的請求至AppContainer子進程,開始調試過程(處理netcoredbg調試事件)。

VSCode調試協議參考:

  1. https://github.com/Microsoft/vscode-debugadapter-node/blob/master/debugProtocol.json
  2. https://github.com/Microsoft/vscode-debugadapter-node/blob/master/protocol/src/debugProtocol.ts

1.2 調試演示

  1. 目前僅實現了通過滑鼠定位變數查看相應值;
  2. 尚未實現查看虛擬實體類及其成員的值。

二、服務性能監測

  作為一名程式設計師,系統性能優化是一場持久戰,目標是追求用更少的資源來滿足系統的運行要求。作者在設計之初就定下了整個架構必須包含完整的系統監控功能,以方便快速定位系統瓶頸。因此作者在服務端的服務實例容器內埋了監測點(Pormetheus的Histogram指標類型),用以監測服務實例的調用次數與響應時間。集群內的Prometheus節點定期採集與存儲監測指標,通過運維管理系統的「服務監控」面板(如下圖所示)可以查看某一時間範圍內服務調用次數與耗時的排名,這樣程式設計師就可以重點分析與優化這些服務模型的程式碼。

運維管理系統由框架本身實現,入口為http://地址:5000/ops

三、本篇小結

  本篇介紹了如何實現IDE的服務模型調試與性能監測功能,GitHub上的運行時已更新可供測試。一邊碼程式碼一邊碼文實屬不易,作者需要您的支援請您多多點贊推薦!