Enterprise Integration Patterns (EIP)是 Gregor Hohpe 和 Bobby Woolf 的一本書,以模式語言的形式描述了 65 種用於使用 企業應用程序集成 和麵向消息的中間件的模式。它們幫助我們使用標準化的方式來集成應用程序,而無需在每次遇到問題時都重新發明輪子。
企業集成模式的目標是創建一種通用語言和一組工作流操作,以便將它們組合在一起以創建成熟、實用的業務流程。它提供了一個包含 65 種模式的目錄,可幫助您為您的企業設計有效的消息傳遞解決方案。
本書區分了四種頂級集成替代方案:
- 文件傳輸
- 共享數據庫
- 遠程過程調用
- 消息傳遞
引入了以下集成類型:
- 信息門戶
- 數據複製
- 共享業務功能
- 面向服務的架構
- 分佈式業務流程
- 企業對企業整合
- 緊耦合交互與松耦合交互
使用免費在線工具繪製企業集成模式圖
Visual Paradigm 的免費 企業集成模式工具 (EIP 圖表工具)具有一組編輯功能,使繪圖更簡單、更快捷,例如拖放和對齊指南,使編輯變得流暢和直觀。EIP 圖表工具還附帶一組 EIP 符號和形狀,可讓您創建不同類型的 EIP 圖表。
data:image/s3,"s3://crabby-images/22296/222969c143c32988340d5e8685a8a65eceacbf54" alt=""
您可以輕鬆地開發您的模式,然後通過 PNG、JPG、GIF、SVG 和 PDF 等格式輸出和共享它們。
通過示例和模板學習 EIP
您可以從空白圖表或 EIP 模板開始。以下是一些模板。單擊“編輯”按鈕立即開始編輯。它是免費的,無需註冊。
企業集成模式示例:智能代理
data:image/s3,"s3://crabby-images/f97f7/f97f7ce0cfbdbcd37e21f2dbdda3d7a0fc074a62" alt=""
企業集成模式示例:組合消息傳遞 MSMQ
data:image/s3,"s3://crabby-images/4bbd9/4bbd952ba439d152697d76758db2ddc219f869b1" alt=""
想採用其他一些企業集成模式嗎?
來自 Visual Paradigm的EIP 在線編輯存儲庫
生態工業園區實施框架
Apache Camel 支持 Gregor Hohpe 和 Bobby Woolf 的優秀著作中的大多數 企業集成模式 。基於企業集成模式 (EIP) 通過應用開箱即用的最佳實踐來幫助您解決集成問題。Camel 支持 Gregor Hohpe 和 Bobby Woolf 的優秀著作中的大多數企業集成模式,以及來自 微服務架構的更新集成模式。
如果您是 Camel 的新手,您可能想在嘗試實現這些模式之前嘗試用戶指南中的 入門 。
消息系統
data:image/s3,"s3://crabby-images/38e00/38e003a6e4a3a4eb9376a985789bfee2530ea744" alt=""
留言頻道
一個應用程序如何使用消息傳遞與另一個應用程序通信?
data:image/s3,"s3://crabby-images/2f6a6/2f6a6bffbba0197688af589192eebf17ed07809b" alt=""
信息
通過消息通道連接的兩個應用程序如何交換一條信息?
data:image/s3,"s3://crabby-images/b1c87/b1c87528b394989a3381992e1728734ca5cbb0fd" alt=""
我們如何在保持獨立性和靈活性的同時對消息進行複雜的處理?
data:image/s3,"s3://crabby-images/24c51/24c5150716b5d8fed8e2b77de05c16e1d507f0fe" alt=""
如何解耦各個處理步驟,以便根據一組條件將消息傳遞給不同的過濾器?
data:image/s3,"s3://crabby-images/9523a/9523ae8f7d1651d233d9480082d1b47de25c5045" alt=""
使用不同數據格式的系統如何使用消息傳遞相互通信?
data:image/s3,"s3://crabby-images/f22ae/f22ae9beb08ce31bcb3e0299f09f5682bb11c4e2" alt=""
應用程序如何連接到消息傳遞通道以發送和接收消息?
消息渠道
data:image/s3,"s3://crabby-images/f240e/f240ed733eb8f672887a72327a4d95782e022424" alt=""
呼叫者如何確定只有一位接收者會收到文件或執行呼叫?
data:image/s3,"s3://crabby-images/ccf80/ccf8004dc731b17233973fb27440485462c5a794" alt=""
發送者如何向所有感興趣的接收者廣播事件?
data:image/s3,"s3://crabby-images/e4ae3/e4ae381a3bad17c2deb82ffe6c5df815f058396f" alt=""
消息傳遞系統將如何處理它無法傳遞的消息?
data:image/s3,"s3://crabby-images/9735b/9735b99873e06d2b817a2565e74b499df28bc697" alt=""
即使消息系統發生故障,發件人如何確保消息將被傳遞?
data:image/s3,"s3://crabby-images/7a015/7a015a22f5918acff65af9c8c64268d4c20c03c8" alt=""
如何將應用程序連接到消息傳遞系統以便它可以發送和接收消息?
data:image/s3,"s3://crabby-images/0798f/0798f2eabc8def31d68f11913cc487245a75f67f" alt=""
如何連接多個消息傳遞系統,以便在一個消息系統上可用的消息也可以在其他消息系統上可用?
data:image/s3,"s3://crabby-images/c1fed/c1fed08a22c4bc07acebd3f529bdfdeea3ff2b0b" alt=""
什麼樣的架構能夠使不同的應用程序一起工作,但以一種解耦的方式,以便可以輕鬆地添加或刪除應用程序而不影響其他應用程序?
data:image/s3,"s3://crabby-images/b2a29/b2a29db84fba789309b4c9492fbe747f7dcfc4aa" alt=""
通過捕獲對數據庫所做的更改來同步數據,並將這些更改應用到另一個系統。
消息構造
data:image/s3,"s3://crabby-images/15b20/15b2001190aab44c2156f34492c6a2ede54e8eb6" alt=""
如何使用消息傳遞將事件從一個應用程序傳輸到另一個應用程序?
data:image/s3,"s3://crabby-images/04276/04276ebbb79640cd58abcf59c0356e9d510e20a6" alt=""
當應用程序發送消息時,它如何獲得接收者的響應?
data:image/s3,"s3://crabby-images/c7eec/c7eecac68ca658cc7606f40a5c29a14eff2ea45f" alt=""
回复者如何知道將回復發送到哪裡?
data:image/s3,"s3://crabby-images/853fe/853fe919a5d6fdfe9276ec34d4d75da0834f0ca1" alt=""
收到回复的請求者如何知道這是針對哪個請求的回复?
data:image/s3,"s3://crabby-images/658ef/658ef9e67529bf212d522b42a06170586d15b995" alt=""
發件人如何指示何時應將消息視為陳舊並因此不應處理?
消息路由
data:image/s3,"s3://crabby-images/c9b26/c9b26f3cb5806344211451080b517997020c55bf" alt=""
我們如何處理單個邏輯功能(例如,庫存檢查)的實現分佈在多個物理系統中的情況?
data:image/s3,"s3://crabby-images/d4fcb/d4fcbe1ecc29ebac1cf289f0b2116fc7b1136741" alt=""
組件如何避免接收到無趣的消息?
data:image/s3,"s3://crabby-images/04d31/04d314302e40d78a5cb5027b3ac102a202e33464" alt=""
如何在保持效率的同時避免路由器對所有可能的目的地的依賴?
data:image/s3,"s3://crabby-images/c89e5/c89e5b55566de945b21cdba9f430f4916468c758" alt=""
我們如何將消息路由到(靜態或動態)指定收件人列表?
data:image/s3,"s3://crabby-images/468ab/468abf20eeb0a789ee8b4fa02a045d9a8e595b63" alt=""
如果消息包含多個元素,我們如何處理它,每個元素都可能需要以不同的方式處理?
data:image/s3,"s3://crabby-images/a8842/a88428c29597e6bb53902e66212c53a9524d6e9a" alt=""
我們如何組合單個但相關消息的結果,以便將它們作為一個整體進行處理?
data:image/s3,"s3://crabby-images/4efb4/4efb40f5d25a1fa5baeebbd5e37c27508442eef4" alt=""
我們如何才能將相關但無序的消息流恢復到正確的順序?
data:image/s3,"s3://crabby-images/8b33d/8b33d284c30d12ab189417d20d6ab7c3a4069b0d" alt=""
在處理由多個元素組成的消息時,如何維護整個消息流,每個元素可能需要不同的處理?
當一條消息需要發送給多個收件人時,您如何維護整個消息流,每個收件人都可能會發送回复?
data:image/s3,"s3://crabby-images/0ed9b/0ed9becb9a181c81d9c784d2a5affabc19bcf350" alt=""
當步驟順序在設計時未知並且可能因每條消息而異時,我們如何通過一系列處理步驟連續路由消息?
data:image/s3,"s3://crabby-images/69687/69687fb7fa84b4d9ffadf1c61d98fa8d5ad68e9c" alt=""
當所需的步驟在設計時可能不知道並且可能不是連續的時,我們如何通過多個處理步驟路由消息?
data:image/s3,"s3://crabby-images/14780/14780d78bc3216856bf40b89a863668bce5ea7cb" alt=""
如何將消息的目的地與發送者分離並保持對消息流的集中控制?
如何限制消息以確保特定端點不會超載,或者我們不會超過某些外部服務商定的 SLA?
如何在給定時間內從多條消息中抽取一條消息以避免下游路由不過載?
如何延遲發送消息?
如何在多個端點之間平衡負載?
如果服務中斷,我如何停止調用外部服務?
如何在從某種服務註冊表中查找服務的分佈式系統中調用遠程服務?
如何在 Camel 路線中定義一系列相關操作,這些操作應該成功完成(全部)或不執行/補償?
如何將消息同時路由到多個端點?
如何在循環中重複處理消息?
消息轉換
data:image/s3,"s3://crabby-images/d155e/d155e33a585ceccbef7307c7bc1dffa97d3070a8" alt=""
如果消息發起者沒有可用的所有必需數據項,我們如何與另一個系統通信?
data:image/s3,"s3://crabby-images/aa3a4/aa3a493f91a81be62c43c62b43e7903c1ced1c4e" alt=""
當您只對少數數據項感興趣時,如何簡化對大消息的處理?
data:image/s3,"s3://crabby-images/56f90/56f90be714b437170a5edb7f2143a98ce0c6da19" alt=""
我們如何在不犧牲信息內容的情況下減少跨系統發送的消息的數據量?
data:image/s3,"s3://crabby-images/cc3be/cc3be8b23397cd149232b89d37f98956aba392d6" alt=""
您如何處理語義上等效但以不同格式到達的消息?
如何對郵件正文進行排序?
如何執行可能不會更改消息的腳本?
如何驗證消息?
消息傳遞端點
您如何在域對象和消息傳遞基礎架構之間移動數據,同時保持兩者相互獨立?
data:image/s3,"s3://crabby-images/a3012/a30121b91ea0847a99caa66722d5e541da7265c3" alt=""
應用程序如何在消息可用時自動使用它們?
data:image/s3,"s3://crabby-images/4d2a7/4d2a778f91751092819553c97ba18bce18698222" alt=""
當應用程序準備就緒時,應用程序如何使用消息?
data:image/s3,"s3://crabby-images/e4e96/e4e9692f30b5b45e879c71887cc9bfb085b0251d" alt=""
消息傳遞客戶端如何同時處理多個消息?
data:image/s3,"s3://crabby-images/9f892/9f89272ab58c977e4cd359c5d9919a767086eb98" alt=""
單個通道上的多個消費者如何協調他們的消息處理?
data:image/s3,"s3://crabby-images/cc132/cc1328c257c1a2b9ed573bda92fc52fd44c7c581" alt=""
消息消費者如何選擇它希望接收的消息?
data:image/s3,"s3://crabby-images/1e493/1e493465014936758689e3eadf69f3ad758c48d2" alt=""
訂閱者如何在不收聽消息時避免丟失消息?
消息接收者如何處理重複消息?
data:image/s3,"s3://crabby-images/5354d/5354d9952f8fecffcca567c4f33630b642a9ab20" alt=""
客戶端如何控制其與消息傳遞系統的事務?
data:image/s3,"s3://crabby-images/30159/301592b4978d1ea23a29c5bd3f25b1ca0f6718ee" alt=""
您如何封裝從應用程序的其餘部分對消息傳遞系統的訪問?
data:image/s3,"s3://crabby-images/421d8/421d853094c1d3fac497242f2a73897e4912b3e0" alt=""
應用程序如何設計一項服務,以便通過各種消息傳遞技術和非消息傳遞技術調用?
系統管理
data:image/s3,"s3://crabby-images/ff70f/ff70f0f2957808c01e2acb3a0a2b4b491d8e3688" alt=""
我們如何有效地管理分佈在多個平台和廣泛地理區域的消息傳遞系統?
data:image/s3,"s3://crabby-images/d7f2b/d7f2bb589675163fb157a4869ca51d41af805f3b" alt=""
如何通過中間步驟路由消息以執行驗證、測試或調試功能?
data:image/s3,"s3://crabby-images/a69e7/a69e79779886533070529f0127dee4414b386fa3" alt=""
您如何檢查在點對點通道上傳輸的消息?
我們如何有效地分析和調試松耦合系統中的消息流?
如何記錄處理消息?
Steps 將一組 EIP 組合成一個組合邏輯單元,用於度量和監控。