自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

輕量級架構(gòu)可視化:Coco 實現(xiàn)

開發(fā) 開發(fā)工具
過去的十幾天里,在 Inherd 開源小分隊的努力之下,我們實現(xiàn)了 Coco 的第一個完整的功能 —— 實現(xiàn)對于一個項目的基本架構(gòu)可視化。

[[379863]]

過去的十幾天里,在 Inherd 開源小分隊的努力之下,我們實現(xiàn)了 Coco 的第一個完整的功能 —— 實現(xiàn)對于一個項目的基本架構(gòu)可視化。(PS:Coco 是一個研發(fā)效能分析工具,如團隊發(fā)展現(xiàn)狀(根據(jù)架構(gòu)復(fù)雜度及行數(shù)變更)、團隊演進、歷史分析等。)

于是呢,為了驗證開發(fā)流程的完整性,我們發(fā)布了 0.1.1 版本(當前僅構(gòu)建了 macOS 平臺,其它平臺暫時未構(gòu)建)。在這個版本里,我們實現(xiàn)了兩個主要的命令行工具:

  • coco。通過 CLOC、Git 等對項目進行你那樣的。
  • visual(待改進)。對于 coco CLI 生成的結(jié)果進行可視化。

其中的一個重要的功能便是:交互式架構(gòu)可視化。

架構(gòu)圖真的靠譜嗎?

在軟件開發(fā)中,我們經(jīng)常習(xí)慣性地使用各類可視化工具,如 UML,它們用于讓開發(fā)人員快速了解系統(tǒng)某一部分的架構(gòu),快速熟悉不同元素之間的關(guān)系。相似的,對于架構(gòu)進行可視化,能幫助我們迅速了解系統(tǒng)的現(xiàn)狀,快速找到系統(tǒng)中的問題。

在實踐過程中,我們會有不同的可視化模式:

  • 手繪架構(gòu)圖。
  • UML 圖。用戶根據(jù)用例圖抽象成類,描述類的內(nèi)部結(jié)構(gòu)和類與類之間的關(guān)系,是一種靜態(tài)結(jié)構(gòu)圖。
  • C4 模型。在 C4 模型里,有一個重要的理念就是架構(gòu)的抽象層次是類似于地圖,可以進行縮放。對應(yīng)的一個體現(xiàn)就是:系統(tǒng) System、容器 Container、組件 Component和代碼 Code。通過不同層次的系統(tǒng)上的連接,我們可以有機地看到整個系統(tǒng)的組成。而不同的開發(fā)人員,也可以看到適用于自身的架構(gòu)模式。

回到真實世界中,我們往往對于架構(gòu)圖的真實性會產(chǎn)生一些懷疑。為此,我們往往會回到代碼中,去看看真實世界的架構(gòu)長什么樣,又或者是引入 ArchGuard 這樣的工具進行架構(gòu)守護。

于是,在 Coco 中,我們實現(xiàn)的第一個功能,就是輕量級的架構(gòu)可視化。

輕量級架構(gòu)可視化

主流編程語言的分層架構(gòu)是與目錄結(jié)構(gòu)相綁定的,即以文件系統(tǒng)的方式約束其組織形式。于是,當前 Coco 的架構(gòu)可視化針對的主要是分層架構(gòu),即文件 + (PS:目錄結(jié)構(gòu)。如果我們能在 Coco 里實現(xiàn) C4 模型,那自然也是不錯的。)

在這種模式之下,我們只要實現(xiàn)對所有代碼文件的行數(shù)統(tǒng)計,獲取這些數(shù)據(jù)之后,對其進行可視化后,我們便能得到一份輕量級的可視化架構(gòu)。

為此,在 Coco 中,我們用到了:

  • CLOC (Count Lines of Code),是一類可以統(tǒng)計多種編程語言中空行、評論行和物理行的工具。
  • D3.js,是一個使用動態(tài)圖形進行資料可視化的 JavaScript 程序庫。

兩者結(jié)合之下,我們就能可視化現(xiàn)有軟件的分層架構(gòu),并且實現(xiàn)它的交互式設(shè)計 —— 如對于某一代碼倉庫的繼續(xù)展開等等。

使用 Coco 進行架構(gòu)可視化

(PS:由于精力的原因,當前雖然構(gòu)建了不同的操作系統(tǒng)版本,但是只有 macOS 版本是經(jīng)過測試的。)

Coco 首頁:https://github.com/inherd/coco

過程如下:

  • 安裝 coco??梢詮?Release 頁面下載對應(yīng)的二進制包,又或者是從源碼中構(gòu)建。
  • 配置。根據(jù) Coco 的 README.md 編寫 Coco 的配置文件 coco.yml,配置對應(yīng)的代碼倉信息??梢允沁h程的項目,也可以是本地的項目,又或者是 .。
  • 分析。執(zhí)行 coco。
  • 可視化。執(zhí)行 visual server 就可以運行起 Web 服務(wù),通過瀏覽器可以訪問當前的架構(gòu)分析結(jié)果。

示例

如下是 Redis 的結(jié)果圖(125,842 行):

 

代碼結(jié)構(gòu)很清爽,有木有。打開 deps 可以發(fā)現(xiàn),依賴主要是在: jemalloc、 lua 和 hiredis 三個模塊:

 

如下是早期在 GitHub 上泄露的 B 站后端源碼(3,007,351 行,含依賴):

 

對應(yīng)的代碼熱點圖:

 

更多示例見:https://inherd.github.io/cases/

其它

歡迎大家試用或者加入開發(fā)。

GitHub:https://github.com/inherd/coco

本文轉(zhuǎn)載自微信公眾號「phodal」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系phodal公眾號。   

 

責任編輯:武曉燕 來源: phoda
相關(guān)推薦

2025-02-19 09:55:39

2022-05-12 08:58:03

開源日志查詢日志可視化

2017-10-14 13:54:26

數(shù)據(jù)可視化數(shù)據(jù)信息可視化

2020-03-11 14:39:26

數(shù)據(jù)可視化地圖可視化地理信息

2014-05-28 15:23:55

Rave

2021-09-27 08:31:01

數(shù)據(jù)可視化柱狀圖折現(xiàn)圖

2022-12-29 09:49:06

輕量級架構(gòu)決策

2022-08-26 09:15:58

Python可視化plotly

2009-04-21 14:26:41

可視化監(jiān)控IT管理摩卡

2014-12-31 16:48:43

Touch touchevent多點觸摸

2013-06-20 10:28:39

MVVM框架avalon架構(gòu)

2017-03-28 14:57:23

kylinsuperset可視化

2019-08-06 10:35:25

Python時間序列可視化

2022-09-29 11:16:21

Python數(shù)據(jù)可視化

2015-08-20 10:06:36

可視化

2023-11-26 09:06:46

2013-05-15 10:20:16

Paas虛擬化

2022-05-16 11:39:46

云架構(gòu)云可視化CROPS

2009-07-14 18:05:28

輕量級Swing組件

2009-07-17 14:38:51

輕量級Swing組件
點贊
收藏

51CTO技術(shù)棧公眾號