做者 | 唐志龍(鯤龍) 阿里巴巴高級開發工程師mysql
導讀:本文總結了熟悉系統主要分三部分:業務學習、技術學習、實戰。每部分會梳理一些在學習過程當中須要解答的問題,這些問題隨着經驗的積累須要逐步補充完善。sql
開發人員常常會面臨下面一些場景:數據庫
這樣的場景多了,就須要去梳理常見問題以及應對方法,方便後續遇到相似場景能夠快速應對。本文總結熟悉系統主要分三部分:業務學習、技術學習、實戰。每部分會梳理一些在學習過程當中須要解答的問題,這些問題隨着經驗的積累須要逐步補充完善。apache
業務學習就是從業務角度去學習系統,咱們須要瞭解系統的客戶是誰、使用人是誰、帶來了什麼價值,系統提供了哪些功能等。不清楚業務,就等於不知道系統在幹什麼。技術是爲業務落地而服務,清楚了業務才知道怎樣用技術更好地服務業務,因此業務學習是熟悉一個系統的首要任務。這塊主要的學習方式有跟產品、運營、開發溝通,學習產品設計文檔文檔、PRD、本身使用系統,還有一些常見圖,如產品功能架構圖、業務流程圖、功能樹,用例圖等。安全
常見問題:網絡
技術學習主要學習系統的架構、如何實現、系統的運維等。描述一個系統的架構有五視圖方法論。架構
五視圖分別是:併發
邏輯架構着重考慮功能需求,系統應當向用戶提供什麼樣的服務,關注點主要是行爲或職責的劃分。經常使用表達圖形,靜態圖有包圖、類圖、對象圖;動態圖有序列圖、協做圖、狀態圖、活動圖。邏輯架構的核心設計任務是模塊劃分、接口定義、領域模型細化。mvc
常見問題:oracle
開發架構關主要關注系統源代碼、第三方 SDK、使用的框架、中間件、工具包。
常見問題:
運行架構的着重考慮運行期質量屬性,關注點是系統的併發、同步、通訊等問題,這勢必涉及到進程、線程、對象等運行時概念,以及相關的併發、同步、通訊等。
常見問題:
物理架構的設計着重考慮安裝和部署需求,關注點是目標程序及其依賴的運行庫和系統軟件最終如何安裝或部署到物理機器,以及如何部署機器和網絡來配合軟件系統的可靠性、可伸縮性、持續可用性、性能和安全性等要求。
常見問題:
數據架構的設計着重考慮數據需求,關注點是持久化數據的存儲方案,不只包括實體及實體關係數據存儲格式,還可能包括數據傳遞、數據複製、數據同步等策略。
常見問題:
系統運維重點關注何時會出問題,出了問題怎麼解決。
常見問題:
熟悉了系統的業務和技術後,就要實戰了,經過實戰進一步加深對系統的熟悉程度。實踐能夠經過作需求、修 bug、重構等方式,親自動手編碼、調試、測試、上線。
已有系統一般經歷了從 0 到 N 的建設過程,熟悉系統實際上是一個逆向推導過程,也是一個學習架構、閱讀源碼的過程。在學習的過程當中最好能帶上思考,好比爲何要這麼設計?爲何要用這個中間件?是否有更好的編碼方式?哪些地方能夠優化等,以此達到一個深刻熟悉的過程。
附:總結圖
「阿里巴巴雲原生關注微服務、Serverless、容器、Service Mesh 等技術領域、聚焦雲原生流行技術趨勢、雲原生大規模的落地實踐,作最懂雲原生開發者的技術圈。」