1. 程式人生 > >目前開源ESB產品介紹

目前開源ESB產品介紹

Mule

它是一個輕量級的訊息框架和整合平臺,基於EIP(Enterprise Integeration Patterns,由Hohpe和Woolf編寫的一本書)而實現的。
Mule的核心元件是UMO(Universal Message Objects,從Mule2.0開始UMO這一概念已經被元件Componse所代替),UMO實現整合邏輯。
UMO可以是POJO,JavaBean等等。
它支援20多種傳輸協議(file,FTP,UDP,SMTP,POP,HTTP,SOAP,JMS等),並整合了許多流行的開源專案,比如Spring,ActiveMQ,CXF,
Axis,Drools等。雖然Mule沒有基於JBI來構建其架構,但是它為JBI容器提供了JBI介面卡,應此可以很好地與JBI容器整合在一起。而 Mule更關注其靈活性,高效性以及易開發性。從2005年發表1.0版本以來,Mule吸引了越來越多的關注者,成為開源ESB中的一支獨秀。目前許多公司都使用了Mule,比如Walmart,HP,Sony,Deutsche Bank 以及 CitiBank等公司。

Apache ServiceMix

它是JBI規範的一種實現。它包涵了許多JBI元件,這些元件支援多種協議,比如JMS,HTTP,FTP,FILE等。同時也實現了EIP,規則和排程。自從JBI被JCP接收後,2005年末Apache ServiceMix才被Apache作為其卵化專案,到2007年9月,它已經成為Apache的頂級專案。ApacheServiceMix 也整合了其他的開源專案,比如Apache ActiveMQ,Apache CXF,Apahe Camel,Apache ODE以及Apache Geronimo。
說起Apache ServiceMix,就會使我想到LogicBlaze公司。它曾經是Apache ServiceMix和Apache ActiveMQ的商業支持者。2006年LogicBlaze被IONA成功收購後,IONA負責為Apache ServiceMix提供支援和服務。同時IONA也將Apache ServiceMix作為FUSE平臺中的一員,FUSE旗下還包括Apache ActiveMQ,Apache CXF,Apahe Camel,FUSE HQ。
官方網站:
http://servicemix.apache.org/

Fuse平臺的官方網站:http://open.iona.com/products/fuse-esb/

Open ESB

前兩個開源ESB都由開源社群提供支援,Mule由Codehaus社群提供支援,ServiceMix由Apache社群提供支援。Open ESB是由SUN發起,現在作為Java.net的子專案。所有Open ESB的開發人員都來自SUN。
如同Apache ServiceMix一樣,Open ESB也實現了JBI規範。Open ESB可執行在由SUN支援的Glassfish應用服務中。同時SUN的Netbeans IDE為Open ESB提供了拖拉式的開發工具,這是其他開源ESB不可匹敵的,儘管Mule也提供了基於Eclipse的外掛工具,但目前仍然不夠強大。

官方網站:https://open-esb.dev.java.net/

Apache Synapse

雖然Apache Synapse具備一些ESB所必備的功能,但是從本質上而言Synapse更是一個web服務仲裁框架,它是構建在Apache Axis2之上的。Synapse的關注點是路由,轉換,訊息驗證以及基於web服務和xml標準的註冊。它支援HTTP, SOAP, SMTP, JMS,FTP ,MTOM/XOPPOP3/IMAP/SMTP 等傳輸協議,還支援多種web服務規範(WS-*),比如WS-Addressing,WS-Security,WS-Policy以及WS- Reliable Messaging。在它的最新版本1.2中加入了對FIX(Financial Information eXchange,金融資訊交換協議 ) 和 Hessian 的支援。同時它還支援多種流行語言,比如Java, JavaScript, Ruby, Groovy等。
官方網站:http://ws.apache.org/synapse

JBoss ESB

JBoss ESB是基於JBoss公司的ESB產品Rosetta的。Jboss ESB將JbossMQ作為其訊息層,將JBoss rules為其提供路由功能,
將jBPM為其提供服務編排功能。足以見得JBoss的野心。

官方網站:http://labs.jboss.com/jbossesb/