什么是软件开发脚手架,为什么需要脚手架,常用的脚手架有哪些
為什么需要腳手架
為什么軟件開發需要腳手架呢?我們通過軟件開發的一些基本原則看一下腳手架對軟件工程的重要作用。
● 復用原則(Reuse Principle):現在我們推崇的是極致化的編程體驗,縮短的開發時間、大量的開發任務、支持需求的變更、高頻率的應用服務交付,這些都給軟件開發人員帶來了前所未有的壓力。其中,軟件復用技術被公認為解決這些問題的行之有效的方法。從計算機軟件編程的發展歷史來看,從面向過程的編程語言到面向對象的高級編程語言的廣泛使用,是軟件復用技術進步的體現。從對象的復用到更大的組件復用,再到如今的框架的復用、服務的復用,都是在利用他人的優秀成果來放大你的工作價值。當一個新手使用腳手架時,對于一個具體問題,可以套用現成的解決方案加以擴展。使用腳手架的應用,僅需通過簡單的注解和配置就可以具備健康狀態檢查、生產環境就緒、可觀測等基本服務能力。對于一個業務邏輯問題,可以復用已有的邏輯,一步步迭代,敏捷開發。
● DRY原則(Don’t Repeat Yourself):DRY原則直譯過來就是“不要重復你自己”。這一原則和復用原則類似,強調盡量在項目中減少重復的代碼行、重復的方法、重復的模塊。其實,軟件設計原則和模式最本質的思想都是“消除重復”。
我們經常提到的重用性和可維護性其實是基于減少重復這一簡單而重要的思想的。DRY原則意味著系統內的每一個部件都應該是唯一的,并且是具有明確含義的(不模糊的)。我們可以通過應用職責單一、接口隔離等原則盡量拆分系統、模塊、類和方法,使每一個部件都是職責明確并且可重復使用的。
● 開閉原則(Open Close Principle):開閉原則中的“開”就是指對功能的擴展是開放的,“閉”是指對于原有代碼的修改是封閉的。通俗一點講,軟件系統通常是由各種模塊組成的,軟件系統在增加一項新的功能時,應該在不修改現有代碼的基礎上操作。實現開閉原則的關鍵就是“抽象”,從微觀的角度講,開閉原則適用于一個業務模型的類的設計,把系統內的所有可能行為抽象為一個抽象底層,在這個抽象底層中規定需要提供的方法接口,具體實現類通過集成、代理、委托的方式,擴展實現新的行為或者新的功能。從宏觀的角度講,我們說開閉原則就是將公共模塊、開發約定、最佳技術實踐經過共享、提煉沉淀到封閉的底層技術基座;而將變化頻繁的業務模塊、獨特的功能邏輯通過繼承、組合和集成的方式實現對擴展的開放。
不要重新 《一線大廠Java面試題解析+后端開發學習筆記+最新架構講解視頻+實戰項目源碼講義》無償開源 威信搜索公眾號【編程進階路】 造輪子
不要重新造輪子(Stop Reinventing The Wheel),這個原則可以說是軟件開發里的“金科玉律”。在實際的軟件工程場景中,腳手架的使用正是為了我們避免重新造輪子。如果你不借助已有框架或者工具,不僅不會提升開發效率,還會將自己陷入重新造輪子的風險中。這里舉一個發生在本人參與的實際項目中的血淋淋的案例。
我們在一個服務治理項目中需要在數據持久層實現一個通用的數據存儲接入組件,初衷是降低應用接入不同數據存儲引擎的復雜性,屏蔽使用者對不同持久層的感知差異,使開發者通過簡單的配置就能適配不同的數據類型。另外,因為期望完全掌握對持久層的控制,以及實現深度定制化的數據轉換功能,所以我們并沒有使用Spring框架,而是走上了自研持久層的道路。如下圖所示是自研持久層的UML框架圖。
我們分別對接了MySQL、MongoDB、OpenTSDB、HBase等數據源。系統從架構設計到落地花費了大概兩個月的時間,還不包括后期的測試、對接、調試、修復Bug至少一個月的磨合期。然而,由于人員、經驗、項目周期等各種因素,最終自研持久層框架的效果并沒有達到預期,后期在與業務對接的過程中還出現了各種技術和業務適配問題。
在經過一番技術調研后,我們決定逐漸使用Spring Data替代原有的自研持久層框架。經過項目的實踐后,我們發現在業務的需求滿足性、易用性、開發效率、業務穩定性等各個方面,Spring Data都具備壓倒性的優勢,它不僅可以完全滿足業務和技術上的需求,而且可以簡化我們的開發工作、顯著提升工作效率。二者的復盤對比如下表所示。
Spring Data項目通過使用對象的語義可以讓我們更方便地操作不同類型的數據。它將應用的骨架部分通過“抽象”提取出來,形成了一套系統的開發范式和行為模式。Spring Boot腳手架也為自定義的復雜查詢、修改操作提供了擴展的Repository類和自動化配置,使添加定制化的擴展方法更加輕松方便。我們只需要理解Spring為我們提供的操作API接口,就可以實現復雜的查詢等業務邏輯。
Spring Data將我們的數據持久層框架進行了進一步的封裝,開發者通過簡單的注解,就可以實現將不同類型數據放到不同持久層集合的存儲映射操作。可以說,腳手架工程可以為開發人員屏蔽繁雜的數據存儲引擎底層差異和具體工作細節,提升了開發效率,降低了開發難度。除非你是這個領域的專家,或者沒有現成的軟件腳手架能夠滿足你的需求,否則請停止“愚蠢地重復造輪子”的行為。
常用腳手架
=====
下面列舉一些軟件開發中經常使用的腳手架,看一下如何通過腳手架提高我們的開發效率。
Vue框架
對于前端開發人員來說,Vue無疑是一套簡單的、易于使用的構建用戶界面的前端腳手架。根據Vue的官網說法,Vue是一套構建用戶界面的漸進式的JavaScript框架。與其他重量級框架不同的是,Vue采用自底向上的增量開發的設計,Vue的目標是通過盡可能簡單的API實現響應的數據綁定和組合的視圖組件。
vue-cli腳手架構建工具,可用于快速搭建大型單頁應用。該工具提供“開箱即用”的構建工具配置,帶來了現代化的前端開發流程。
只需幾分鐘即可創建并啟動一個帶熱重載、保存時靜態檢查及可用于生產環境的構建配置的項目:
要創建基于Webpack模板的項目,首先我們選定目錄,然后在命令行中把目錄轉到選定的目錄即可,可以使用下面的命令:
Maven
Maven是一個跨平臺的項目管理工具,是服務于Java平臺的項目構建、依賴管理、項目信息管理工具。同時使用Maven可以規范項目骨架及包層次結構、命名配置文件、生成代碼原型等。
Maven提供了archetype插件來幫助開發人員快速勾勒出項目的骨架,要使用本地Maven倉庫中的腳手架創建新項目,直接執行如下Maven命令,根據提示依次輸入groupId、version、package信息即可:
Maven自動化構建簡化了開發人員手動構建工程的過程,規范了項目的構建過程。Maven自動化構建流程如下圖所示。
Netty
總結
以上是生活随笔為你收集整理的什么是软件开发脚手架,为什么需要脚手架,常用的脚手架有哪些的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: QQ邮箱更新 - 优化标签、短消息、会话
- 下一篇: python培训中心-西安python培