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

来源: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
  • 在一些複雜的業務表中間查詢數據,有時候操作會比較複雜一些,不過基於SqlSugar的相關操作,處理的代碼會比較簡單一些,以前我在隨筆《基於SqlSugar的開發框架循序漸進介紹(2)-- 基於中間表的查詢處理》介紹過基於主表和中間表的聯合查詢,而往往實際會比這個會複雜一些。本篇隨筆介紹聯合多個表進行... ...
  • 從按鈕、文本框到下拉框、列表框,WPF提供了一系列常用控制項,每個控制項都有自己獨特的特性和用途。通過靈活的佈局容器,如網格、堆棧面板和換行面板,我們可以將這些控制項組合在一起,實現複雜的界面佈局。而通過樣式和模板,我們可以輕鬆地定製控制項的外觀和行為,以符合我們的設計需求。本篇記錄WPF入門需要瞭解的樣式... ...
  • 以MySQL資料庫為例 # 一. 安裝 NuGet搜索Dapper.Lite並安裝最新版本。 ![](https://img2023.cnblogs.com/blog/174862/202306/174862-20230602155913303-757935399.jpg) NuGet搜索MySql ...
  • # 圖片介面JWT鑒權實現 # 前言 之前做了個返回圖片鏈接的介面,然後沒做授權,然後今天鍵盤到了,也是用JWT來做介面的許可權控制。 然後JTW網上已經有很多文章來說怎麼用了,這裡就不做多的解釋了,如果不懂的可以參考下列鏈接的 文章。 圖片介面文章:[還在愁個人博客沒有圖片放?](https://w ...
  • ![線程各屬性縱覽](https://img2023.cnblogs.com/blog/1220983/202306/1220983-20230603114109107-477345835.png) 如上圖所示,線程有四個屬性: - 線程ID - 線程名稱 - 守護線程 - 線程優先順序 ### 1. ...
  • 本次主要介紹golang中的標準庫`bytes`,基本上參考了 [位元組 | bytes](https://cloud.tencent.com/developer/section/1140520) 、[Golang標準庫——bytes](https://www.jianshu.com/p/e6f7f2 ...
  • 歡迎來到本篇文章!通過上一篇什麼是 Spring?為什麼學它?的學習,我們知道了 Spring 的基本概念,知道什麼是 Spring,以及為什麼學習 Spring。今天,這篇就來說說 Spring 中的核心概念之一 IoC。 ...
  • # 2022版本IDEA+Maven+Tomcat的第一個程式(傻瓜教學) ​ 作為學習Javaweb的一個重要環節,如何實現在IDEA中利用Maven工具創建一個Javaweb程式模版並連接Tomcat發佈是非常重要的。我比較愚鈍(小白),而且自身電腦先前運行過spring或maven的程式,系統 ...
  • 本篇專門扯一下有關 QCheckBox 組件的一個問題。老周不水字數,直接上程式,你看了就明白。 #include <QApplication> #include <QWidget> #include <QPushButton> #include <QCheckBox> #include <QVBo ...
  • # 1.列表數據元素排序 在創建的列表中,數據元素的排列順序常常是無法預測的。這雖然在大多數情況下都是不可避免的,但經常需要以特定的順序呈現信息。有時候希望保留列表數據元素最初的排列順序,而有時候又需要調整排列順序。python提供了很多列表數據元素排序的方式,可根據情況選用。 ## 1.永久性排序 ...