通过运行示例从WSO2 ESB开始
我最近加入了一個新任務,在該任務中,我們必須基于WSO2工具棧實施ESB解決方案。 盡管我熟悉ESB的大多數概念以及其他一些實現(例如Mule ESB ),但這是我第一次必須使用WSO2 ESB 。 幸運的是,可以找到很多文檔 ,并且該工具附帶了大量示例,介紹如何使用ESB。 在這篇文章中,我展示了使第一個示例正常工作的步驟。 有關更詳盡的說明,請參見此處的信息。
第一步是下載并安裝ESB,這確實很容易。 您可以在此處下載zip。 下載后,只需將其解壓縮到要安裝該工具的位置即可。 我安裝在目錄中
'用戶/pascal/develop/wso2esb-4.5.1? 解壓縮后,您將在解壓縮的文件夾中看到文件“ INSTALL.txt”。 在此文件中,所有信息都說明了如何啟動和停止ESB。 要使用樣本,您必須使用以下命令啟動ESB:
其中“ $ {sample-number}”是您要運行的樣品編號。 因此,要使用示例1運行ESB,只需使用以下命令啟動ESB:
'./wso2esb-samples.sh -sn 1'并且您將看到這樣的日志記錄:
請注意,通過修改目錄“ $ CARBON_HOME / repository / conf /”中的“ log4j.properties”,我將“ org.apache.synapse”包的日志級別設置為DEBUG。 第一個示例主要基于代理或重定向到現有服務。 這些服務基于Axis2,并且隨WSO2 ESB的安裝一起提供。 要啟動Axis2服務器,請打開一個新的終端窗口,瀏覽至目錄'$ CARBON_HOME / samples / axis2Server',然后執行命令'./axis2server.sh'。 如在日志記錄的控制臺中所示,這將啟動SimpleAxisServer:
如果打開瀏覽器并導航到'http://localhost:9000/services' ,將會看到我們當前沒有正在運行的服務:
要部署服務,例如SimpleStockQuoteService,請打開一個新終端并導航到以下目錄:$ CARBON + HOME / samples / axis2Server / src / SimpleStockQuoteService。 在這里,只需提供“ ant”命令,即可將服務編譯,構建并部署到我們之前啟動的Axis2Server:
現在,如果我們查看'http://localhost:9000/services'我們將看到SimpleStockService可用于請求:
如果需要,可以使用SoapUI測試服務:
因此,現在我們已經為第一個示例準備好了服務器端。 讓我們運行客戶端。 每個樣本都有說明如何運行Axis2客戶端的文檔。 對于樣本1,文檔顯示如下:
打開一個新終端,瀏覽到以下目錄“ /Users/pascal/develop/wso2esb-4.5.1/samples/axis2Client”,并提供所述命令以運行客戶端:
如您所見,我們收到了IBM股票的報價。 在運行WSO2 ESB的終端中,我們看到由傳入請求引起的以下日志記錄:
[2013-03-03 16:58:03,113] DEBUG - SynapseMessageReceiver Synapse received a new message for message mediation... [2013-03-03 16:58:03,114] DEBUG - SynapseMessageReceiver Received To: /services/StockQuote [2013-03-03 16:58:03,114] DEBUG - SynapseMessageReceiver SOAPAction: urn:getQuote [2013-03-03 16:58:03,114] DEBUG - SynapseMessageReceiver WSA-Action: urn:getQuote [2013-03-03 16:58:03,114] DEBUG - Axis2SynapseEnvironment Injecting MessageContext [2013-03-03 16:58:03,115] DEBUG - Axis2SynapseEnvironment Using Main Sequence for injected message [2013-03-03 16:58:03,115] DEBUG - SequenceMediator Start : Sequence <main> [2013-03-03 16:58:03,115] DEBUG - SequenceMediator Sequence <SequenceMediator> :: mediate() [2013-03-03 16:58:03,115] DEBUG - InMediator Start : In mediator [2013-03-03 16:58:03,115] DEBUG - InMediator Current message is incoming - executing child mediators [2013-03-03 16:58:03,115] DEBUG - InMediator Sequence <InMediator> :: mediate() [2013-03-03 16:58:03,115] DEBUG - FilterMediator Start : Filter mediator [2013-03-03 16:58:03,116] DEBUG - FilterMediator Source : get-property('To') against : .*/StockQuote.* matches - executing child mediators [2013-03-03 16:58:03,116] DEBUG - FilterMediator Sequence <FilterMediator> :: mediate() [2013-03-03 16:58:03,116] DEBUG - SendMediator Start : Send mediator [2013-03-03 16:58:03,116] DEBUG - EndpointContext Checking if endpoint : endpoint_d06dafda969c8e11992a8e8f5366fd33203399eaae89984c currently at state ACTIVE can be used now? [2013-03-03 16:58:03,116] DEBUG - AddressEndpoint Sending message through endpoint : endpoint_d06dafda969c8e11992a8e8f5366fd33203399eaae89984c resolving to address = http://localhost:9000/services/SimpleStockQuoteService [2013-03-03 16:58:03,116] DEBUG - AddressEndpoint SOAPAction: urn:getQuote [2013-03-03 16:58:03,116] DEBUG - AddressEndpoint WSA-Action: urn:getQuote [2013-03-03 16:58:03,117] DEBUG - Axis2FlexibleMEPClient Sending [add = false] [sec = false] [rm = false] [mtom = false] [swa = false] [format = null] [force soap11=false] [force soap12=false] [pox=false] [get=false] [encoding=null] [to=http://localhost:9000/services/SimpleStockQuoteService] [2013-03-03 16:58:03,117] DEBUG - Axis2FlexibleMEPClient Message [Original Request Message ID : urn:uuid:381071f8-c6ca-4e14-bfe4-0e53de7f7cc2] [New Cloned Request Message ID : urn:uuid:503aabca-2a04-413f-ba44-b6c623bf9db6] [2013-03-03 16:58:03,117] DEBUG - SynapseCallbackReceiver Callback added. Total callbacks waiting for : 1 [2013-03-03 16:58:03,119] DEBUG - SendMediator End : Send mediator [2013-03-03 16:58:03,120] DEBUG - DropMediator Start : Drop mediator [2013-03-03 16:58:03,120] DEBUG - DropMediator End : Drop mediator [2013-03-03 16:58:03,120] DEBUG - FilterMediator End : Filter mediator [2013-03-03 16:58:03,120] DEBUG - InMediator End : In mediator [2013-03-03 16:58:03,120] DEBUG - SequenceMediator End : Sequence <main> [2013-03-03 16:58:03,130] DEBUG - SynapseCallbackReceiver Callback removed for request message id : urn:uuid:503aabca-2a04-413f-ba44-b6c623bf9db6. Pending callbacks count : 0 [2013-03-03 16:58:03,132] DEBUG - SynapseCallbackReceiver Synapse received an asynchronous response message [2013-03-03 16:58:03,133] DEBUG - SynapseCallbackReceiver Received To: null [2013-03-03 16:58:03,133] DEBUG - SynapseCallbackReceiver SOAPAction: [2013-03-03 16:58:03,133] DEBUG - SynapseCallbackReceiver WSA-Action: [2013-03-03 16:58:03,134] DEBUG - SynapseCallbackReceiver Body : <?xml version='1.0' encoding='utf-8'?><soapenv:Envelope xmlns:soapenv='http://schemas.xmlsoap.org/soap/envelope/'><soapenv:Body><ns:getQuoteResponse xmlns:ns='http://services.samples'><ns:return xmlns:ax21='http://services.samples/xsd' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:type='ax21:GetQuoteResponse'><ax21:change>4.155006565416989</ax21:change><ax21:earnings>-8.118428276798063</ax21:earnings><ax21:high>84.31871512134151</ax21:high><ax21:last>80.49639852693167</ax21:last><ax21:lastTradeTimestamp>Sun Mar 03 16:58:03 CET 2013</ax21:lastTradeTimestamp><ax21:low>-79.94179251359746</ax21:low><ax21:marketCap>-6855110.427635921</ax21:marketCap><ax21:name>IBM Company</ax21:name><ax21:open>83.68193468970854</ax21:open><ax21:peRatio>23.68015151185118</ax21:peRatio><ax21:percentageChange>-5.440098733913549</ax21:percentageChange><ax21:prevClose>-76.37741093768571</ax21:prevClose><ax21:symbol>IBM</ax21:symbol><ax21:volume>16034</ax21:volume></ns:return></ns:getQuoteResponse></soapenv:Body></soapenv:Envelope> [2013-03-03 16:58:03,134] DEBUG - Axis2SynapseEnvironment Injecting MessageContext [2013-03-03 16:58:03,135] DEBUG - Axis2SynapseEnvironment Using Main Sequence for injected message [2013-03-03 16:58:03,135] DEBUG - SequenceMediator Start : Sequence <main> [2013-03-03 16:58:03,135] DEBUG - SequenceMediator Sequence <SequenceMediator> :: mediate() [2013-03-03 16:58:03,135] DEBUG - InMediator Start : In mediator [2013-03-03 16:58:03,135] DEBUG - InMediator Current message is a response - skipping child mediators [2013-03-03 16:58:03,135] DEBUG - InMediator End : In mediator [2013-03-03 16:58:03,135] DEBUG - OutMediator Start : Out mediator [2013-03-03 16:58:03,136] DEBUG - OutMediator Current message is outgoing - executing child mediators [2013-03-03 16:58:03,136] DEBUG - OutMediator Sequence <OutMediator> :: mediate() [2013-03-03 16:58:03,136] DEBUG - SendMediator Start : Send mediator [2013-03-03 16:58:03,136] DEBUG - SendMediator Sending response message using implicit message properties.. Sending To: http://www.w3.org/2005/08/addressing/anonymous SOAPAction: [2013-03-03 16:58:03,138] DEBUG - SendMediator End : Send mediator [2013-03-03 16:58:03,138] DEBUG - OutMediator End : Out mediator [2013-03-03 16:58:03,138] DEBUG - SequenceMediator End : Sequence <main>最后,在Axis2Server終端中,由于示例流將請求傳遞到端口9000,因此將以下行添加到日志記錄中:
Sun Mar 03 16:58:03 CET 2013 samples.services.SimpleStockQuoteService :: Generating quote for : IBM 這表明該示例運行正常,并且已執行所有預期的操作。 下一步將通過所有其他示例,以更好地理解WSO2 ESB的可能性。
參考: 從WSO2 ESB開始,在The Pragmatic Integrator博客上運行我們的JCG合作伙伴 Pascal Alma 的示例 。
翻譯自: https://www.javacodegeeks.com/2013/03/starting-with-wso2-esb-by-running-the-samples.html
總結
以上是生活随笔為你收集整理的通过运行示例从WSO2 ESB开始的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用Spring Security添加R
- 下一篇: 安评报告包括哪些内容 安评报告要写什么