我的軟考歷程
摘要
2023年2月,我所在的公司通過了研發紗線MES系統的立項,該系統為國內紗線工廠提供SAAS服務,旨在提升紗線工廠的數字化和智能化水平。我在該項目中擔任架構設計師,負責該項目的架構設計工作。本文結合我在該項目中的實踐,詳細論述了常見的軟件開發模式如瀑布模型、原型模型、螺旋模式等,本項目采用了瀑布模型和原型模型結合的方式,把項目周期分成了需求分析、系統設計、程序設計、編碼實現和測試驗收等階段,并通過快速原型獲取了用戶的需求,整個過程進展順序,保證了系統的穩定開發。最終在2023年12月,該項目正式上線對外提供服務,至今穩定運行,各項功能和性能指標均達到了客戶的要求,受到了客戶工廠和公司領導的一致好評。
項目背景
隨著我國從制造業大國升級為制造業強國以及工廠數字化和智能化的持續推進,我所在的某地某科技公司基于自研的物聯網平臺相繼開發了染整一體化和織布一體化等系統,這些系統上線后,得到了工廠的追捧,也為公司帶來了豐厚的經濟回報。基于此,我司于2023年2月開始研發紗線MES系統,該系統總投資730萬,開發周期10個月,涵蓋紗線工廠從清花、梳棉、并條、精梳、粗紗、細紗到絡筒的全流程工序,將為紗線工廠提供全面的生產管理解決方案以及基于數據的智能決策分析能力。該項目采用物聯網層次架構,整體分為感知層、網絡層和應用層。其中網絡層為公司已有的物聯網平臺,這次重點建設內容為感知層和應用層,感知層使用Golang語言開發,作為聯網網關部署在工廠側,負責工廠數據的采集和云端指令的下發。應用層為紗線MES系統主體,采用Java語言開發,使用Spring Cloud微服務架構,數據庫使用Mysql,緩存使用Redis,前端框架使用vue.js,日志、監控和鏈路追蹤采用skywalking、prometheus、grafana和ELK,最終通過devops的方式部署在kubernetes集群中。系統上線后,將提供以下:基礎管理、數據接入、工單排產、數字孿生、工資計算、智控中心和數據分析等等功能,通過以上功能,可以全面提升紗線工廠的數字化和智能化水平,使其運營水平和生產效率得到質的提升。
論述內容
由于該項目涉及參與者眾多,業務流程長,數據處理量大,邏輯復雜,同時邊端部署環境不穩定,云端流量壓力大。所以,為了保障該項目的順利開發和運行的穩定性,我們團隊一致認為需要采用合理的軟件過程模式來保證項目的開發。目前常用的開發模型有:
1、瀑布模型,是一種線性的模型,它把項目開發過程分為了若干個階段,只有前一個階段完成后,后一個階段才能進行。這種做法可以控制各個階段的執行工作和內容,有利于管理項目。但是,該做法要求需求明確,如果前一個階段出現了問題,這個問題會影響后面的所有的階段,造成項目的失敗和延期。
2、原型模型,是一個迭代開發模型,它通過快速的構件一個簡單的原型來驗證需求和涉及方案。它的特點是迭代開發、快速反饋和不斷的優化。通過原型模型,可以讓用戶的需求明確起來,用戶在這個過程中也會參與原型的體驗,可以及時得到用戶的反饋,進行需求確認,通過這種方式,可以有效的降低風險,減少后期返工。
3、螺旋模型,螺旋模型是瀑布模型和原型模型的結合,它把開發過程分為了多個迭代周期,每個周期都有需求分析、設計、編碼、測試等階段,同時螺旋模型強調了風險的重要性,它在每個循環階段中都加入了風險分析。基于此,螺旋模型很適合大型的復雜的項目,通過它,可以有效地降低開發的風險。
經過團隊的討論并結合該項目的特點,大家一致決定使用瀑布模型和原型模型結合的方式,這種方式既能有效地對項目的開發進行管理,同時也能保證需求的準確性,降低項目的風險,減少返工的概率。我們把項目分為需求分析、系統設計、程序設計、編碼實現和測試驗收等階段,并通過快速原型去獲取用戶需求。具體開發過程如下。
一、需求分析階段
我們嚴格制定了需求收集和分析計劃,把系統分為了多個系統,每個子系統都有專門的同事去負責。同時,我們對系統進行了分解,通過領域建模的方式把系統分為了多個微服務如工資計算、基礎管理、絡筒、細紗、報表等領域,每個領域都負責自身的業務,都有自己的數據字典。最后,大家對所有的數據字典進行統一,保證所有項目參與者都對系統有著相同的理解和認識。具體而言,絡筒是紗線工廠的一個重要工序,絡筒機是絡筒工序的設備,絡筒可以把細紗通過絡筒設備轉化成絡筒。從絡筒這個工序上而言,它是一個比較獨立的模塊,可以獨立地進行建模,并采用一個微服務去實現它。再比如說,細紗也是紗線工廠的一個重要工序,它把粗紗通過細紗機的一步步地處理,最后生產了細紗,所以它也是一個獨立的工序,可以采用領域建模去分析它,并使用一個微服務去實現它。除了具體的功能需求外,我們的專家也提出了很多非功能性需求,比如1、邊端采集的設備數據,需要在一分鐘內上報到云端MES系統;2、物聯網平臺需要支持5萬家工廠;3、當工廠有了新需求后,云端MES系統需要在7日內完成調整上線;4、重要的數據需要采用加密處理;像這樣的需求有一百多條。當其他需求基本確定后,就剩下工資領域的需求存在問題,這部分的需求變化太大,不同的工廠有不同的工資計算方式,為了讓這部分的需求明確,我們使用了原型模型,讓前端開發了一個簡易原型,然后,讓工廠的人來使用,并反饋意見,通過多次的反饋和修改,最終確認了工資領域的需求。最后,我們編寫了需求規格說明書,為后續的開發奠定了基礎。
二、系統設計階段
我們根據需求規格說明書進行了架構設計、數據設計、用戶界面設計和過程設計。架構設計方面,由于我們對整個系統做了領域劃分,所以大家一致決定采用微服務架構的方式來開發我們的系統。具體而言,我們采用Spring Cloud微服務,使用Nacos作為服務注冊發現中心。數據設計方面,我們對各個領域做了實體分析,通過ERD識別了每個領域的實體,并對這些實體進行了數據庫層面的設計和表設計,在存儲方面,我們采用每個微服務一個數據庫的方式,保障微服務的數據獨立性。在用戶界面設計方面,我們前端團隊設計了全套的UI,包括色系、字體、布局、導航、圖片等等,保證了局面的統一,讓前端頁面具有簡單、一致性的特點。過程設計方面,我們根據需求規格說明書中的業務流程要求,進行了過程設計,保證了業務流程的正確性和高效性。最后,我們編寫了系統設計文檔。
三、程序設計和編碼階段
我們根據需求規格說明書和系統設計文檔,進行了詳細的程序設計和編碼工作。在程序設計中,需要考慮到程序的正確性、可讀性、可維護性和可擴展性。不僅如此,我們還要注意程序的性能和安全性的問題。比如,由于每個工廠的工資計算的方式都不一樣,我們在設計工資計算時,就要考慮到計算方的可擴展性,通過使用策略設計模式和腳本引擎相結合的方式,有效地提交了工資計算的可擴展性,只需要通過動態的編寫腳本就可以實現工資計算方式的擴展。在安全性方面,針對工資中的個人信息做了加密處理,確保信息的安全。在編碼階段,我們需要遵循變成規范和標準,確保代碼的正確性,并通過單元測試保證代碼質量。
總結
由于采用了瀑布模型和原型模型相結合的方式,我們有效地保證了項目的進度,同時降低了項目的風險,避免了功能的返工。最終在2023年12月,該項目正式投產并對外提供服務,至今穩定運行,各項功能和性能指標均遠遠超過了客戶的預期,得到了客戶工廠和公司領導的一致贊揚。雖然項目取得了成功,但是也遇到過一些問題,在項目初期,由于產品經理對紗線業務的不熟悉,導致很多功能的調整和返工,這打擊了開發人員的士氣,基于此,我提出兩個解決方式:1、派產品進入工廠一線,與工人交流,熟悉操作流程,徹底摸清紗線業務,保證需求質量;2、開發人員也要學習紗線業務,遇到問題反饋給產品,同時在做設計時,采用靈活的設計模式,為需求的變動留下可操作的空間。我們通過這兩個方法解決了這個問題,保證了項目的進展。通過這次實踐,我不僅學習到了軟件過程模型相關的技術,也鍛煉了自己的架構和管理能力,我意識到只有不斷地學習和實踐才能讓知識融匯于自己的技術體系之中,才能在未來的工作中游刃有余、勇擔大任,為祖國的信息化建設貢獻自己的力量。