工作中一些原則體會

来源:https://www.cnblogs.com/xiaoqiang-code/archive/2019/09/19/11553197.html
-Advertisement-
Play Games

儘可能讓一切變得簡單,用最簡單的方式完成工作 能用最少的概念,最精簡易懂的概念模型來抽象系統,多一個概念就多一份別人瞭解系統以及維護系統的複雜度,別人也會質疑多一個概念的意義所在,自己如果沒想清楚就容易被diss。 特別是在類的設計中,會發現其實很多時候用一個類就可以表達要乾的單一職責了,每個類職責 ...


儘可能讓一切變得簡單,用最簡單的方式完成工作

能用最少的概念,最精簡易懂的概念模型來抽象系統,多一個概念就多一份別人瞭解系統以及維護系統的複雜度,別人也會質疑多一個概念的意義所在,自己如果沒想清楚就容易被diss。

特別是在類的設計中,會發現其實很多時候用一個類就可以表達要乾的單一職責了,每個類職責清晰,類於類之間關係易於理解及維護。

設計系統時某些功能只在需要它時構建

對於這點深有體會, 特別是在對設計此類系統沒有業務經驗的時候,不要嘗試第一次就構建一個所謂“完美”系統,系統是要面向迭代的,永遠都是隨時準備修改或增加功能,所以設計系統的目標不在於追求一次性構建完美全面的功能,而在於追求系統對功能支持的擴展性,是否能具有快速cover新業務需求,從而分秒迭代自身的能力。

並且業務是多變的,設計時滿足好當前的功能需求,並預留擴展點,即使目前功能不完備,也能在未來快速構建它。

沒必要過度設計,特別是在自身經驗不豐富的情況下,意淫的美好都是太自我,雖然多思考敢於嘗試是好事情,但還是要找高手明確好要做的事情,否則對開發人力的浪費。開發暫時不需要的功能會導致最“重要且緊急”的需求delay或bug風險

敏捷迭代思維

先學會爬,然後再學會走,最後學會跑。換句話說,先保證能夠正常運行,然後優化它使其更好,最後逐漸讓它變得完美。為每個功能制定一個開發周期(最多2周),然後不斷迭代。

註重投資回報率

工作中會發現任務都是排著隊的,至於任務隊列的 compare方法怎麼寫,對於事情的四象限法則,事情的投資回報率是評估是否重要的重要考量。

功能的設計和測試儘可能獨立。如果在設計時考慮到這一點,長遠來看,它將省去很多麻煩,否則只有一切構建完成時你才可以開始測試整個系統。很多時候直到要測試某個功能的時候,才發現代碼相互依賴,而無法獨立測試某模塊。

推行MVP(最小可行產品)

該理念的核心在於:先制定一些用例,完成用例所涉及的相關功能,立即發佈產品,然後根據反饋和經驗對產品進行優化。

在需求評審階段儘可能明確要做的事情,知悉pm需求的業務意義,才能更好更明確的帶著目標做事情,技術評審階段,儘量想清楚需求邊界及所需的技術和業務資源來評估好開發時間,並乘以一個繫數作為交付時間(主要是為後期突然插入的事情留buffer),從項目生命周期開始,直到上線期間,和相關人員經常進行 關鍵步驟同步和確認,大家不會天天盯著你在做的事情,要主動同步進度,尋求反饋,可以避免方向走偏,同時方便對於領導也能掌控全局信息。

在多人協作過程中,流程規範化的意義,比如結論文檔化,分支管理按照契約。大家都有了common sense,辦公效率也是極大提高。

試想微服務系統節點較少,倆人協作的時候,信息的溝通等價於最簡單的的Pub/Sub模型,信息的傳遞較為簡單,大家都會把對方同步給自己的事情處理好,甚至還閑著沒事兒催促你好幾遍,因為每個人只訂閱對方的消息,來源單一,處理起來不會遺忘。後來的後來系統複雜了(同事多了),你作為生產者有了好多個消費者同事,比如你要改一個介面,涉及到好幾個其他模塊開發者,你推動這次升級需要每階段都push各方同事這時候有個問題:

除了其它端,發現 支付端 也需要升級你的介面,然後屁顛屁顛跑人家那又巴拉巴拉描述如何升級——每個消費者接入,都需要生產者開發適配新消費者的消息發送代碼。

學會解耦

別忘了工作中你本身作為生產者同時也在訂閱別人,總之你作為一個節點,你的所有peer消息你都要處理,消息量大還處理不過來,容易遺漏。要麼是push消息,要麼是處理別人的消息,對於push別人的消息,你還要做好“降級”,因為你告訴別人這樣做了,你確保不了別人一定按你說的做,消息一多這個時候人腦子會很容易亂的,別人如果做錯了,如果不承認你給他push過消息怎麼辦?你要背鍋嘛。。。

怎麼辦呢? 引入業務消息中間件~

所以人多了就得學會解耦,每個模塊都有人專門負責,模塊間的溝通工作,需要一種協議來確保溝通準確性和解耦,上面說的是典型的同步rpc協議,意味著你要瞭解所有的消費者,還要處理新來的消費者,沒有消息落盤,不可追溯。如果這個時候有一些文檔或消息群來承載結論性的消息變更,大家都只需要跟蹤這個文檔或這個群就可以了,生產者就往裡push消息,剩下的分散式消息處理一致性讓別人來保證就可以了,哪一端沒處理好,怪不了你了可。

首先不用處理對別方的降級,都按文檔約定的來的,也同步給你了,對於新的消費者接入,看文檔就好了。 每個人就只需要push消息到文檔落盤,訂閱別人的文檔watch變更,大量消息落盤,個人可以非同步消費,而不會丟消息,落盤的消息可重覆消費,可記錄歷史,避免溝通的扯皮,確保研發環節的有條不紊。當系統更大的時候,每個人工作消息模式複雜度保持不變,這也是 消息中間件 消息消峰 解耦的意義。

還沒關註我的公眾號?

  • 掃文末二維碼關註公眾號【小強的進階之路】可領取如下:
  • 學習資料: 1T視頻教程:涵蓋Javaweb前後端教學視頻、機器學習/人工智慧教學視頻、Linux系統教程視頻、雅思考試視頻教程;
  • 100多本書:包含C/C++、Java、Python三門編程語言的經典必看圖書、LeetCode題解大全;
  • 軟體工具:幾乎包括你在編程道路上的可能會用到的大部分軟體;
  • 項目源碼:20個JavaWeb項目源碼。
    小強的進階之路二維碼

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

-Advertisement-
Play Games
更多相關文章
  • 題目一:旋轉數組的最小數字 思路:說實話看這個題目看了好久題目愣是沒看懂,到底是個什麼數組啊,又不說清楚,emmm...百度了好久才知道這個數組預設其中的元素的遞增的,而且在數組中的元素可能是重覆的,比如2344445這種也是行的,我們就分別討論一下有重覆元素和沒有重覆元素的情況; 第一種情況:數組 ...
  • 深入理解JVM垃圾回收機制 1、垃圾回收需要解決的問題及解決的辦法總覽 + 1、如何判定對象為垃圾對象 引用計數法 可達性分析法 + 2、如何回收 回收策略 標記 清除演算法 複製演算法 標記 整理演算法 分帶收集演算法 垃圾回收器 serial parnew Cms G1 + 3、何時回收 下麵就是如何判 ...
  • 作業一: 1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 #先定義一個函數 5 def func(args): 6 #定義一個計算數字的變數 7 digit_num = 0 8 # 定義一個計算字母的變數 9 al_num = 0 10 # ...
  • 1.jps(JVM Process Status Tool) 列出正在運行的虛擬機進程。 2.jstat(JVM Statistics Monitoring Tool) 顯示運行狀態信息。 3.jinfo(Configuration Info for Java) 查看和調整虛擬機各項參數。 4.jm ...
  • 一、線程池工作流程   1. 線程池判斷核心線程池裡的線程是否都在執行任務。如果不是,則創建一個新的工作線程來執行任務(需要獲得全局鎖)。如果核心線程池裡的線程都在執行任務,則進入下個流程。 2. 線程池判斷工作隊列是否已滿。如果工作隊列沒有滿,則將新提交的任務存儲在這個工作隊列里。如果工 ...
  • 一、測試Web服務 二、模擬Web測試 三、測試業務組件 四、模擬業務組件 ...
  • 使用PyCharm向世界打招呼! print (“Hello world!”) 介紹自己的基本信息的方法 ...
  • centos7上部署dubbo管理控制台dubbo admin 1 準備工作 伺服器:系統centos7, 記憶體4G, 存儲60G, ip 192.168.159.128 軟體環境: 安裝有jdk1.8, 具體安裝方式參見《centos7上安裝jdk1.8》博文; 安裝並啟動zookeeper,具體 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...