真正整合是你無法通過購買低程式碼工具實現的 - Byars
這是martinfowler.com的Brandon Byars文章,詳細點選標題見原文:
整合軟體產品——ESB、ETL 工具、API 平臺和雲整合服務——不是直接解決業務問題的產品。它們不屬於同一類別,例如,欺詐檢測產品或分析產品或 CRM。它們是程式語言,捆綁了工具鏈和執行時以支援編譯過程。當您購買整合產品時,即表示您同意使用這些商業程式語言構建整合本身。
整合工具幾乎總是低程式碼平臺,這意味著它們旨在通過提供圖形設計調色盤來簡化開發工作,您可以將整合工作流拖放到上面。但在幕後,該平臺將原始碼儲存為 JSON 或 XML,並嵌入了一個執行時,該執行時知道如何將標記解釋為實際的機器程式碼。
簡化介面的關鍵是接受更復雜的實現。
簡化整合的程式碼當然是一項崇高的努力,整合工具可以提供幫助,但還不能足以在功能上構建乾淨的介面。
重要的是,判斷一個介面是否容易使用的唯一有效判斷是它的實際使用者。
Google 本來可以要求我們提供更多資訊以使他們的搜尋實施更容易——例如,地理、新近度和流行度資訊——但他們只提供了一個文字框來輸入搜尋,並且必須學習如何將這些因素應用到他們的演算法。
同樣的問題也適用於 API 設計(我將其廣泛定義為包括同步呼叫和非同步事件)。
乾淨的介面隱藏了實現細節,整合上下文中的這些實現細節之一是程式語言的選擇。
我們需要轉變思維方式,從思考如何使用我們的工具解決整合問題,轉而思考如何構建正確的介面以最大限度地提高敏捷性。
使用通用程式語言來管理介面演變
像Java這樣通用程式語言的生態系統發展迅速:測試工具、IDE、可觀察性工具和更好的抽象的進步受益於此類語言所執行社群的龐大規模。而低程式碼平臺的生態系統要小得多,限制了以相同速度推進的能力,並且平臺約束將幾乎可以肯定,開發人員必須使用供應商提供的工具鏈來編寫和測試程式碼。這自然會對供應鏈和靜態分析掃描等安全問題產生影響。這種工具在 Java 開源庫等方面受到了很多關注,但在低程式碼世界的圍牆花園中卻很少受到關注。
低程式碼工具不足以處理通用程式語言可以處理的相同型別的複雜性:
我的一位同事描述了一個有爭議的環境,他正在處理使用 TIBCO BusinessWorks(一種著名的商業整合工具)的任務。他向 TIBCO 團隊發起挑戰:他會派他最好的 Java/Spring 開發人員建立與另一個 COTS 產品的 Web 服務(在 Apache Axis 中編碼的 SOAP 介面)的整合,並且他們可以讓他們最好的 TIBCO 開發人員做同樣的事情. Java 開發人員在午餐前完成了一個工作實現。TIBCO 團隊發現該工具不支援 COTS 產品使用的舊版本 Apache Axis,大型企業中常見的遺留複雜性型別。遵循授權意味著回到供應商那裡並更改他們的路線圖或新增通用程式語言的擴充套件。Fred Brooks 在他的著名著作中稱這種擴充套件為“偶然的複雜性”。
然而,比通過商業工具執行所有整合所需的偶然複雜性更令人擔憂的是,這樣的任務將重點放在實現而不是介面、系統而不是功能上。
整合工具在實施方面“思考”
由於跨 IT 系統範圍解鎖資料和功能的複雜性,整合工具被建立並在今天繼續蓬勃發展。例如,您的實際客戶主資料可能存在於 SAP 中,但客戶生命週期的早期部分存在於 Siebel CRM 中。IBM 大型機系統仍然為一些客戶處理核心計費;其他人的 Oracle ERP。現在,該企業希望用 Salesforce 取代 Siebel。引入新產品的業務團隊自然明白需要一些時間才能獲得正確的配置以使其適應他們的銷售流程,但他們最不想要的就是被告知冗長的 IT 時間表只是為了整理系統之間的粘合劑。
應用程式整合的早期是企業服務匯流排 (ESB),它將系統連線作為可重用元件與編排和路由分離。您可以在簡化的檢視中看到這種分離 Mulesoft 的 ESB,之所以如此命名是因為它旨在消除整合的“驢工作”:
由於業界渴望在匯流排上擁有企業範圍的規範格式,因此在 ESB 世界中有一些自然的錯誤開始,但所有這些都共享介面卡的概念,用於匯流排的輸入和輸出 - 系統被整合。在愉快的路徑中,您可以使用像 BPEL 這樣的語言來描述您的整合,它可以提供圖形設計調色盤和源圖同構,就像它在 XML 中描述的過程一樣。
該行業在很大程度上已從 ESB 轉移,但您可以在現代 API 平臺中看到它們的傳統。例如,看一下 Mulesoft 的三層 API 架構。
Mulesoft 銷售 API 管理平臺和用於構建 API 的低程式碼執行時。您可以而且經常應該購買中介軟體基礎設施,完全有可能將 API 閘道器與執行時分離,代理到以通用程式語言構建的 API。如果你這樣做了,問題就出現了:如果你在 Mulesoft 執行時之外構建了所有的 API,你會使用 Mulesoft 的三層架構嗎?
我對 Mulesoft 模型的主要批評是對實現問題的強調:因為我認為這導致我們將整合視為一種戰術問題。(整合應該是戰略問題)
相關文章
- 真正整合是你無法透過購買低程式碼工具實現的 - Byars
- 低程式碼與無程式碼真正的區別是什麼
- Appsmith:真正的低程式碼開源開發工具APPMIT
- 通過阿里雲命令列工具 aliyuncli 購買伺服器阿里命令列伺服器
- 無程式碼和低程式碼最大的區別是什麼?
- 在數小時內構建 CRM:你需要了解的頂級無程式碼/低程式碼工具
- 低程式碼VS無程式碼
- 實現簡單的`Blazor`低程式碼Blazor
- 你真的使用過低程式碼產品嗎?
- 低程式碼 系列 —— 中後臺整合低程式碼預研
- 玩家是如何在Steam上購買遊戲的? 玩家購買遊戲決策過程實錄遊戲
- 低程式碼和無程式碼的區別
- 低程式碼無程式碼開發工具:TOP10排名
- RestCloud API低程式碼開發平臺,實現無程式碼快速釋出APIRESTCloudAPI
- 低程式碼優於無程式碼?
- “低程式碼”是什麼?低程式碼平臺如何助力企業實現數字化轉型?
- 企業中的低程式碼與無程式碼
- 低程式碼和無程式碼的注意事項
- 通過Rxjs五行程式碼實現EventBusJS行程
- 零程式碼整合自動化的實現邏輯是什麼?
- 通過 App Groups 實現程式間通訊APP
- 通過正則高效實現千位符(一行程式碼你敢信?)行程
- 購買低程式碼平臺,必須考慮的關鍵指標和注意事項指標
- 低程式碼&無程式碼,你知道該怎麼區分和選擇嗎?
- Flutter | 通過 ServiceLocator 實現無 context 導航FlutterContext
- 什麼是低程式碼的窘境?
- 什麼程式碼是ChatGPT無法編寫的? - datachimpChatGPT
- 低程式碼是什麼?
- 通過Go實現AES加密和解密工具Go加密解密
- Rainbond通過外掛整合SkyWalking,實現APM即插即用AI
- .net 程式通過 crontab 無法啟動,手動執行指令碼可以啟動指令碼
- 無程式碼相對於低程式碼的優勢分析
- 低程式碼是什麼意思?低程式碼平臺的技術特點是什麼?
- 低程式碼是開發的未來嗎?淺談低程式碼平臺
- 通過.net core原始碼看下Dictionary的實現原始碼
- 通過管理工具(hgdbdeveloper)新建使用者無法授權Developer
- 無程式碼和低程式碼有哪些區別
- P1108 低價購買 題解