如何讓技術架構師具有預知未來業務發展的能力?

来源:https://www.cnblogs.com/Jcloud/archive/2023/05/18/17410985.html
-Advertisement-
Play Games

大家好,今天我們來分享業務架構,但是我們並不是以產品經理角度講述一個業務架構是什麼以及如何做?而是以一個技術架構師的角度,講述如何承接業務架構或在沒有業務架構的時候,如何判斷業務變化趨勢而對系統架構提前做出反應。 ...


大家好,今天我們來分享業務架構,但是我們並不是以產品經理角度講述一個業務架構是什麼以及如何做?而是以一個技術架構師的角度,講述如何承接業務架構或在沒有業務架構的時候,如何判斷業務變化趨勢而對系統架構提前做出反應。

一、發生背景

研發人有技術架構,產品經理有業務架構(通常是一個人),當一個技術架構師不懂業務架構的時候,就會出現如下對話。

技術工程師小王:“產品經理又改需求,昨天和我說訂單按照庫存狀態拆分,我剛剛上線今天又和我說按照促銷類型類型拆分”

架構師小孫:“業務本來就發展迅速的,那天他還和我說想根據商品體積拆分的,被我擋了回去”。

技術工程師小王:“厲害,還是你有話語權”。

我相信大家經常遇到類似的問題,然而如果技術架構師懂業務架構,就會變成下麵的對話場景。

技術工程師小王:“產品經理又改需求,昨天和我說訂單按照庫存狀態拆分,我剛剛上線今天又和我說按照促銷類型類型拆分,還好,你上次和我說這塊規則是多變的,讓我把不同訂單拆分邏輯,拆分為原子化,我改下配置就搞定,不愧是架構師,你怎麼知道這塊多變?難道會占卜?”

架構師小孫:“哈哈,預知未來本來就是架構師的職責”。

技術工程師小王:“快教教我吧”。

下麵我們就來學習下如何,如何讓技術架構師具有預知未來業務發展的能力。

二、解決方案

技術架構師需要瞭解業務架構的知識,但是又不用像產品經理知道那麼多,例如價值鏈等等概念。他需要知道的如何識別業務發展變化趨勢,並把對應部分的技術架構做好結構化、擴展性。我今天就來介紹一個簡單的方法- MIT知識模型。簡單來說是 1:映射(Mapping) 2 識別(identify) 3 詢問(ask about)

映射(Mapping):所有的需求可以映射到如下系統化、結構化的語言,電腦程式是在什麼樣的場景(事件)下開始行動,程式需要讀取哪些數據(實體),依據什麼樣的順序(活動)、規則(任務)由誰(組織/角色)執行,執行後會產生哪些數據(實體)。但是針對一個特定的場景來說,順序(活動)、規則(任務)由誰(組織/角色)是更容易多變的。

識別(identify)&詢問(ask about****):所以我們在和產品經理溝通需求的時候,最主要的是識別順序、規則(組織/角色通常在許可權系統RBAC模型可以配置,可以不用多考慮)。如何快速識別順序和規則呢?

1、 順序:一個場景經過的多個業務活動,這個通常產品經理的業務流程圖會展示,例如商品引入功能,需要經過“洞察”、“選品”、“招商”、“法務”等多個業務流程節點。找到這個順序後,主要問產品2個問題就可以判斷是否多變,“這個順序,是否在不同客戶/渠道/品類等不同端或渠道不同”,“這個順序,是否因為短期上線壓力,妥協只是做了簡化”。通常產品經理在調研的時候會獲得這個信息。如果產品經理不確定,可以讓產品經理在調研下,有個這個信息,在系統架構處理的時候,就可以有多種方式處理擴展性,可以做出多個微服務,或者利用流程引擎工具實現擴展性。

2、規則:通常是( IF A then B)模式,他通常在在每個順序節點下麵,例如在商品引入的“洞察”的業務活動時候,如果發現有如下話術“如果商品是大家電,需要考慮競對價格因數”,“如果商品是滯銷類型,可以不用參與洞察”等等。如果發現這類術語,基本可以判斷是規則;當然還有些規則比較隱蔽,需要我們來挖掘,例如案例中“訂單按照庫存狀態拆分,我剛剛上線今天又和我說按照促銷類型類型拆分”,這裡其實並沒有那麼明顯的( IF A then B)模式,但是通常有形容詞的動詞,都有可能變化(例如 按照庫存狀態拆分)。但是如果在挖掘下或仔細思考下,就可以看出出來這個兩個拆分邏輯,一定是有條件或順序的,否則同一個訂單拆分會亂套的。如果在這個時候,我們在追問下產品2個問題,“1、這個規則,是否在特定的條件下才有效,例如客戶/渠道/品類等不同端或渠道、時間段、優先順序順序”。“2、這個規則,在不同客戶/渠道/品類等不同端或渠道,還有可能其他規則“。同樣,如果產品經理不確定,可以讓產品經理在調研下,有個這個信息,在系統架構處理的時候,就可以多種方式處理擴展性,最簡單代碼的可以做策略模式,或利用配置文件、規則引擎dools等實現擴展性。

三、案例分析

通過以上簡單的模型,我們就客戶還原架構師小孫,在和產品經理溝通的需求場景。

產品經理小李:“這次我們要做個業務,訂單履約。這是我的PRD,今天我們一起看下。。。。。。“

架構師小孫:“PRD寫的挺詳細的。通過我這個PRD。我們理解了訂單履約大概要實現的功能,你看我這樣說是否正確:訂單履約功能需求,需要讀取訂單數據,在經過拆分、打標順序,產生多個拆單後訂單,並傳輸給物流系統。通常這些工作,由系統自動處理無需人員干涉。是吧?

產品經理小李:“是的,大的邏輯是這樣的”

架構師小孫:“這裡拆分、打標順序,否在不同客戶/渠道/品類等不同端或渠道不同。是否因為短期上線壓力,妥協只是做了簡化?“

產品經理小李:我調研了4個客戶,3個訂單渠道,以及競品都是經過這個這幾個環節。目前看沒有在新節點的可能性。

架構師小孫:“好的,那我為了成本考慮。我先把流程節點設計為固定,後續你這裡發現有多變的場景及時通知我,另外我看你在拆分環節,提到訂單按照庫存狀態拆分,這裡是所有訂單都按照庫存狀態拆分嗎?”

產品經理小李:“額,我我覺得是“

架構師小孫:“我建議你在調研下,不同客戶/渠道/品類等不同端或渠道下,是否有不同邏輯”,通常在有形容詞的動作,都是可能變化的。

—— 一段時間後

產品經理小李:“嗯是的,客戶A說他們除了庫存、還有運費、禮品卡、商品體積拆分邏輯,這些會按照順序來依次進行“。

架構師小孫:“OK。這塊我設計為可擴展性的”

四、總結陳述

看,架構師有業務預知性或者業務敏感性其實挺簡單的,就是找對位置,多問些問題,就可以為一線研發減少很多工作量。這個能力在很多地方,也可以稱為業務敏感性。所以系統擴展性設計一定離不開業務輸入,但是如何通過幾個簡單的問題,就可以快速找到業務多變的地方,就是我本次分享的MIT模型解決的。大家也可以請根據一個業務場景,按此MIT知識模型分析下業務多變的點。

來源:京東雲開發者社區

作者:京東零售 李春麗(未經授權請勿轉載)


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

-Advertisement-
Play Games
更多相關文章
  • 一個合格的技術人的內心要時刻謹記自己在一個企業內的價值所在,並不斷的通過技術提升來擴大價值,才可以在當下的環境中,個人價值與企業價值形成正向迴圈。那我們此次就聊一聊,前端職能如何在不同的業務場景中落地價值。 ...
  • AJAX 是Asynchronous JavaScript And XML的縮寫。 它不是一種編程語言。它是一種基於HTML、CSS、JavaScript 和 XML,讓開發更好、更快和更有互動的 Web 應用的技術。 什麼是ajax 認識前後端交互 前後端交互就是前端與後端的一種通訊方式,主要使用 ...
  • 業務場景 二輪充電業務中,用戶充電完成後在訂單詳情頁展示訂單相關信息,用戶點擊分享按鈕喚起微信小程式分享菜單,將生成的圖片海報分享給微信好友或者下載到本地,好友可通過掃描海報中的二維碼加群領取優惠。 使用場景及功能:微信小程式 生成海報圖片 分享好友 下載圖片 使用技術:Taro vue vant ...
  • 完整的可以與資料庫連接的登錄界面的代碼 login.jsp <%@ page language="java" contentType="text/html; UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta chars ...
  • HTTP(Hypertext Transfer Protocol)是一種用於在Web瀏覽器和Web伺服器之間傳輸數據的協議。HTTP的版本有很多,其中比較常見的有 HTTP 1.0 、 HTTP 1.1 和 HTTP 2.0 ,它們有各自的特點。 HTTP 1.0 的特點: 1. 每個請求/響應需要 ...
  • 強大的MongoBson庫 後端開發,統計了一下大概有這些場景需要用到序列化: 對象通過序列化反序列化clone 服務端資料庫存儲數據,二進位 分散式服務端,多進程間的消息,二進位 後端日誌,文本格式 服務端的各種配置文件,文本格式 C#序列化庫有非常非常多了,protobuf,json等等。但是這 ...
  • DDD整潔架構 DDD整潔架構為瞭解決強調用的關係,出現了洋蔥架構(六邊形)架構,就是為了實現依賴倒置 它的思想就是把領域模型放到核心的位置,領域模型是獨立的,不會直接強依賴其他層,而通過適配器來完成領域模型和外層的數據交換。 DDD分層架構和三層架構的區別與關係 DD分層架構和三層架構的區別與關係 ...
  • 性能優化是個系統性工程,巨集觀上可分為網路,服務,存儲幾個方向,每個方向又可以細分為架構,設計,代碼,可用性,度量等多個子項。 本文將重點從代碼和設計兩個子項展開,談談那些提升性能的知識點。 ...
一周排行
    -Advertisement-
    Play Games
  • 下麵是一個標準的IDistributedCache用例: public class SomeService(IDistributedCache cache) { public async Task<SomeInformation> GetSomeInformationAsync (string na ...
  • 這個庫提供了在啟動期間實例化已註冊的單例,而不是在首次使用它時實例化。 單例通常在首次使用時創建,這可能會導致響應傳入請求的延遲高於平時。在註冊時創建實例有助於防止第一次Request請求的SLA 以往我們要在註冊的時候實例單例可能會這樣寫: //註冊: services.AddSingleton< ...
  • 最近公司的很多項目都要改單點登錄了,不過大部分都還沒敲定,目前立刻要做的就只有一個比較老的項目 先改一個試試手,主要目標就是最短最快實現功能 首先因為要保留原登錄方式,所以頁面上的改動就是在原來登錄頁面下加一個SSO登錄入口 用超鏈接寫的入口,頁面改造後如下圖: 其中超鏈接的 href="Staff ...
  • Like運算符很好用,特別是它所提供的其中*、?這兩種通配符,在Windows文件系統和各類項目中運用非常廣泛。 但Like運算符僅在VB中支持,在C#中,如何實現呢? 以下是關於LikeString的四種實現方式,其中第四種為Regex正則表達式實現,且在.NET Standard 2.0及以上平... ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他們的程式記憶體會偶發性暴漲,自己分析了下是非托管記憶體問題,讓我幫忙看下怎麼回事?哈哈,看到這個dump我還是非常有興趣的,居然還有這種游戲幣自助機類型的程式,下次去大玩家看看他們出幣的機器後端是不是C#寫的?由於dump是linux上的程式,剛好win ...
  • 前言 大家好,我是老馬。很高興遇到你。 我們為 java 開發者實現了 java 版本的 nginx https://github.com/houbb/nginx4j 如果你想知道 servlet 如何處理的,可以參考我的另一個項目: 手寫從零實現簡易版 tomcat minicat 手寫 ngin ...
  • 上一次的介紹,主要圍繞如何統一去捕獲異常,以及為每一種異常添加自己的Mapper實現,並且我們知道,當在ExceptionMapper中返回非200的Response,不支持application/json的響應類型,而是寫死的text/plain類型。 Filter為二方包異常手動捕獲 參考:ht ...
  • 大家好,我是R哥。 今天分享一個爽飛了的面試輔導 case: 這個杭州兄弟空窗期 1 個月+,面試了 6 家公司 0 Offer,不知道問題出在哪,難道是杭州的 IT 崩盤了麽? 報名面試輔導後,經過一個多月的輔導打磨,現在成功入職某上市公司,漲薪 30%+,955 工作制,不咋加班,還不捲。 其他 ...
  • 引入依賴 <!--Freemarker wls--> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.30</version> </dependency> ...
  • 你應如何運行程式 互動式命令模式 開始一個互動式會話 一般是在操作系統命令行下輸入python,且不帶任何參數 系統路徑 如果沒有設置系統的PATH環境變數來包括Python的安裝路徑,可能需要機器上Python可執行文件的完整路徑來代替python 運行的位置:代碼位置 不要輸入的內容:提示符和註 ...