從零開始學架構(一):架構師成長路徑

来源:http://www.cnblogs.com/itfly8/archive/2016/11/27/6107068.html
-Advertisement-
Play Games

內容摘要從架構的本質,軟體工程,架構師職責,成長路徑等方面,介紹什麼是架構,架構流程以及架構師職責和成長規劃。 本篇主題一、什麼是架構二、項目中的角色三、架構師職責和工作內容四、架構工作流五、架構師成長路徑六、架構能力模型七、擴展知識八、本章總結 一、什麼是架構架構是系統的藍圖,描述了系統的結構和關 ...


內容摘要
從架構的本質,軟體工程,架構師職責,成長路徑等方面,介紹什麼是架構,架構流程以及架構師職責和成長規劃。

本篇主題
一、什麼是架構
二、項目中的角色
三、架構師職責和工作內容
四、架構工作流
五、架構師成長路徑
六、架構能力模型
七、擴展知識
八、本章總結

一、什麼是架構
架構是系統的藍圖,描述了系統的結構和關鍵決策。包含系統的功能和非功能性需求,如何實現的,系統與子系統是如何劃分的,系統之間如何通信的,系統功能如何設計的和交互的。
包含重要的架構決策,系統組成,功能設計,技術選型,成本分析等
架構的基礎是設計滿足客戶需求的系統,其中包含功能性,非功能性以及質量和約束。

二、項目中的角色
客戶:為系統開發買單的人,關註系統的業務價值。
用戶:使用系統的人,關註是否滿足功能需求,提升效率和易用性等。
項目經理:負責項目管理,組織,協調,溝通等管理工作。
需求分析師:負責需求相關工作,比如業務分析,需求獲取,需求調研,需求管理,編寫需求規格說明書等
系統架構師:負責整體的系統分析,架構規劃,技術選型,核心功能需求和非功能性需求的架構設計。
系統設計師:在架構模型的基礎上,進行核心功能和非核心功能的詳細設計。
開發人員:根據架構設計和詳細設計完成編碼和單元測試,達到提測標準。
測試人員:驗證開發功能是否滿足需求,比如進行功能測試,集成測試,性能測試,壓力測試,安全性測試,回歸測試等。
運維人員:負責部署環境搭建,部署和日常維護。

三、架構師職責和工作內容
架構師在項目中起到承上啟下的作用。建議參與到系統建設過程的全流程中。
架構師的職責如下:
1)支持售前或需求階段,提供概念架構或技術咨詢;
2)系統分析,架構設計,技術選型,產出架構解決方案;
3)指導項目團隊成員,按照架構設計完成,開發,測試和發佈;
4)開發或設計開發框架,制定編碼/編程規範,設計架構原型,驗證架構原型;
5)組織技術或架構培訓,把握技術/架構方向;
6)方案平衡(實現與成本),干係人溝通,技術風險管理,技術領袖等;
按照項目階段,簡述工作內容,如下:
售前階段,給予商務支持,提供系統解決方案和架構咨詢。
需求階段,與需求分析師一起,參與需求溝通,協助完成技術/業務咨詢和需求模型。(好的架構師同時是業務專家)
架構階段:進行系統分析和設計,進行系統抽象,設計系統模型,進行技術原型,開發架構原型等
設計階段:指導設計人員完成詳細設計;
開發階段:指導開發人員按設計實現,解決技術難題。
測試階段:指導測試人員測試工作,特別是非功能需求的測試。
發佈階段:指導部署人員按照部署架構進行部署,及時解答或反饋試運行期間的架構問題。
其他工作:技術選型,人員培訓,技術指導

四、架構工作流程
架構工作流程是一個系統如何從需求,架構到實現的過程和方法。
良好的架構,需要架構師除具備技術和架構設計能力外,還要有良好(豐富)的業務知識。從軟體工程角度,架構師除參與系統的架構設計階段外,還需要參與需求分析階段,開發,測試,發佈,試運行階段。
本節內容,從需求模型和解決方案模型,介紹架構工作的流程。
主要包括需求模型,架構模型,設計模型,解決方案模型,四個方面。
需求模型:參與需求分析和需求模型設計,提供技術建議或引導需求定義,提供解決方案指導。
主要參與者:需求分析師,業務分析師
輔助參與者:架構師,設計師
架構模型:根據需求模型,產出架構模型。
1)選擇架構對象:關鍵流程,核心用例和非功能需求;
2)流程建模:梳理需求關鍵流程,分析業務對象,子系統,模塊,設計出系統的交互流程;
3)領域建模:梳理業務流程中涉及的對象,子系統模塊,劃分子系統,模塊,核心對象,通信機制,事務模型等
4)輸出總體架構:根據領域模型和業務流程模型,結合組件架構,部署架構,通信機制,輸出系統體架構方案。
5)架構驗證:驗證架構可用性,可以用評審或架構原型的方式,進行評審或實際測試驗證。
主要參與者:架構師,架構委員會
輔助參與者:系統設計師,開發人員,測試人員
設計模型:在架構師指導下,根據系統架構,完成各子系統,模塊,功能,介面的概要或詳細設計。
主要參與者:系統設計師,高級工程師
輔助參與者:架構師
解決方案模型:架構模型,設計模型,架構原型等統一組成架構解決方案。
一個完整的系統架構應包括:整體架構,子系統,模塊,功能概要或詳細設計,通信機制,事務機制,介面定義(內部,外部),領域模型,業務流程,資料庫設計,中間件,組件架構,部署架構等
系統架構解決方案標準
1)滿足系統的功能和非功能性需求;
2)符合項目要求的規模和成本;
3)滿足開發,測試和發佈要求;

五、架構師成長路徑
本質:學習,實踐,總結,個人進步和能力成長的過程。
開發工程師:主要在指導下進行開發或獨立進行簡單功能開發。本階段的核心是學好技術本身,多做一些項目,勤奮,思考,總結。這個時期就是學習,實踐讓自己的技能水平不斷提升。空閑時間可以學一些設計模式,軟體工程方面的知識,用於拓展視野和為高級工程師做準備。
當自己的技術能力,項目經驗,編碼水平,設計能力達到一定程度後,就可以升級為高級工程師。
一句話:寫好代碼,積累經驗。
高級工程師:可以獨立或帶領工程師負責某模塊/系統的設計和開發,在技術和項目上有一定的經驗。本階段可以根據自己的職業目標選擇深入技術或學習管理知識。
學習的方向:技術深度,技術廣度,分散式,架構知識和管理知識等。
一句話:技術深入全面,思考完善的系統設計。
系統架構師(技術專家):在某一方面技術達到一定深度,在某些方面有自己的見解和獨立解決問題的能力。可帶領一個技術團隊進行開發和管理工作。可完成需求分析,系統設計,技術選型,架構設計,開發管理等工作。
一句話:技術專家,架構實踐和管理能力。
資深架構師:具備豐富的大型項目,多種項目的需求分析,系統架構,系統設計,項目管理等經驗。在技術的廣度和深度方面,業務知識方面具備專業的建樹。
一句話:大型項目,領域專家和解決方案。
技術總監,CTO,技術副總裁:負責公司整體技術規劃,技術管理,把握技術方向,精通業務和技術,具備良好的溝通,組織和協調能力。
一句話:方向,流程,制度,規範,管理。
以上是個人對職位和能力的總結,供參考。

六、架構師能力模型
從巨集觀角度和專業領域,簡單介紹架構師的能力模型。
6.1 巨集觀角度
深度:在某一項或多項技術領域有一定深度,掌握技術的特點,適應場景和缺點
廣度:多項技術,掌握非技術知識,比如需求,項目,管理等
6.2 專業領域
技術:精通一方面或多方面技術,有自己的見解和實踐經驗;
業務:精通負責領域的業務知識,達到或基本達到領域專家級別;
架構:精通需求分析,系統架構,設計模型,架構模型,具備豐富的架構經驗;
管理:精通技術管理,項目管理和通用管理知識和能力;

七、架構擴展知識
以下內容可自行腦補。
1. 軟體工程
2. 需求工程
3. 項目管理
4. 干係人,涉眾

八、本章總結
從架構的本質,項目角色,架構師職責,軟體工程,成長路徑等方面,介紹了什麼是架構,架構流程以及架構師職責,成長路徑和能力模型。
本篇是根據學到的知識,工作經驗和個人思考 ,進行的總結,供學習參考。不足之處,歡迎大家一起交流。
預告: 第二篇 架構知識領域
2.1架構方法論:面向過程,面向對象,面向方面,面向服務
2.2系統劃分:系統,子系統,模塊,功能,介面
2.3架構基本原則:通用專用,職責分離等
2.4模式:設計模式,架構模式,基礎設施模式
2.5架構視圖:4+1視圖


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

-Advertisement-
Play Games
更多相關文章
  • 簡介 Consul-template是Consul的一個方擴展工具,通過監聽Consul中的數據可以動態修改一些配置文件,大家比較熱衷於應用在Nginx,HAProxy上動態配置健康狀態下的客戶端反向代理信息。GitHub上的文檔比較詳細,這裡簡單做個入門介紹。 關於配置中心不做過多介紹了。簡單描述 ...
  • 本文是根據角落的白板報的《使用ABP實現SwaggerUI,生成動態webapi》一文的學習總結,感謝原文作者角落的白板報。 1 安裝Swashbuckle.core 1.1 選擇WebApi項目,右鍵“管理NuGet程式包”。 1.2 輸入 “Swashbuckle.core”,搜索。選擇Swas ...
  • 本文是根據角落的白板報的《通過ABPboilerplate模版創建項目》一文的學習總結,感謝原文作者角落的白板報。 1 準備 開發環境: Visual Studio 2015 update3 SQL Server 2012 2 創建Demo項目 2.1 進入ABP官網:http://www.aspn ...
  • 一、抽象工廠模式 在工廠方法中, 所創建的汽車都是沒有品牌的汽車. 現在假設, 車子有品牌了, 並且不止只有汽車, 還有自行車的生產. 那麼可以把汽車和自行車做成兩個抽象產品, 代碼如下: 為什麼要把產品做成抽象的呢, 因為雖然各品牌的產品大體相同, 但是其中很多細節還是不一樣的. 所以就產生了兩種 ...
  • 上一篇, 介紹了簡單工廠模式, 在最後提出了一個問題, 如果我的程式需要擴展, 加一種產品進去, 顯然, 簡單工廠是不能勝任此項工作的, 那麼需要另請高明 - 工廠方法模式. 當然, 抽象工廠, 也是可以加產品的, 動態添加程式集, 然後反射的方式就可以創建出我們新加的對象. 不過此處, 主要還是介 ...
  • 一、Servlet簡介 Servlet是sun公司提供的一門用於開發動態web資源的技術。 Sun公司在其API中提供了一個servlet介面,用戶若想用發一個動態web資源(即開發一個Java程式向瀏覽器輸出數據),需要完成以下2個步驟: 1、編寫一個Java類,實現servlet介面。 2、把開 ...
  • 前言: "軟體模式的偉大之處, 就在於他們傳達了許多有用的設計思想. 所以, 在學習了大量模式之後, 就理應成為非常優秀的軟體設計人員, 不是嗎? 當學習、使用了幾十個設計模式之後, 我也曾這樣認為. 模式幫助我開發靈活的框架, 幫助我構建堅固、可擴展的軟體系統. 但是幾年之後, 我卻發現自己在模式 ...
  • 每天一個設計模式-7 生成器模式(Builder) 一、實際問題 在討論工廠方法模式的時候,提到了一個導出數據的應用框架,但是並沒有涉及到導出數據的具體實現,這次通過生成器模式來簡單實現導出成文本,Xml等具體的格式。 導出成文本或Xml等格式的數據時,一般都會有各自的格式,比如:導出的文件都有3個 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...