我最近加入了一个新任务,在该任务中,我们必须基于WSO2工具栈实施ESB解决方案。 尽管我熟悉ESB的大多数概念以及其他一些实现(例如Mule ESB ),但这是我第一次必须使用WSO2 ESB 。 幸运的是,可以找到很多文档 ,并且该工具附带了大量示例,介绍如何使用ESB。 在这篇文章中,我展示了使第一个示例正常工作的步骤。 有关更详尽的说明,请参见此处的信息。

第一步是下载并安装ESB,这确实很容易。 您可以在此处下载zip。 下载后,只需将其解压缩到要安装该工具的位置即可。 我安装在目录中
'用户/pascal/develop/wso2esb-4.5.1? 解压缩后,您将在解压缩的文件夹中看到文件“ INSTALL.txt”。 在此文件中,所有信息都说明了如何启动和停止ESB。 要使用样本,您必须使用以下命令启动ESB:

./wso2esb-samples.sh -sn ${sample-number}

其中“ $ {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开始相关推荐

  1. wso2 esb_通过运行示例从WSO2 ESB开始

    wso2 esb 我最近加入了一个新任务,我们必须基于WSO2工具栈实施ESB解决方案. 尽管我熟悉ESB的大多数概念以及其他一些实现(例如Mule ESB ),但这是我第一次必须使用WSO2 ESB ...

  2. WSO2 ESB(1)

    什么是WSO2 ESB? WSO2 ESB是一个轻量级的易于使用的企业服务资源总线.WSO2 ESB允许系统管理员和SOA架构师,消息路由,虚拟化,中介,转换,日志记录,任务调度,负载平衡,失败了路由 ...

  3. wso2 esb_使用WSO2 ESB构建制造服务总线(MSB)

    wso2 esb 在进入本主题之前,我想介绍一些制造业中常用的术语. 制造执行系统(MES)一词是AMR Research在1990年提出的,从先进的制造计算机信息系统的发展到现在,MES概念已经发展 ...

  4. 使用WSO2 ESB构建制造服务总线(MSB)

    在开始讨论本主题之前,我想介绍一些制造业中常用的术语. 术语制造执行系统(MES)由AMR Research于1990年提出,从先进的制造计算机信息系统的发展,MES概念已经发展了近三十年. 以下是制 ...

  5. WSO2 ESB的一种消息传递方式

    正如我之前在WSO2 ESB工作时所发布的那样. 为了更好地理解此ESB,我一直在浏览示例 (尚未完成所有示例 ). 示例12是关于与ESB的单向消息传递,并使用TCP监视器使其可见. 我之前已经介绍 ...

  6. wso2 esb_使用WSO2 ESB进行邮件内容过滤

    wso2 esb 每个集成设计师或开发人员都应该熟悉Gregor Hohpe和Bobby Woolf所描述的企业集成模式(EIP) . 模式之一是"内容消息过滤器" (不要与消息过 ...

  7. WSO2 ESB 学习(二) ---安装篇

    1:先决条件 2:下面的步骤将带领你在windows上安装WSO2 ESB 下载 WSO2 ESB二进制包. 解压zip包到年装好的 WSO2 ESB 设置 JAVA_HOME 环境变量和PATH环境 ...

  8. WSO2 ESB(4)

    WSO2的企业服务总线(ESB)的用户指南 用户指南介绍了如何配置WSO2 ESB使用基于Web的管理控制台. WSO2的管理控制台已经过测试的Mozilla Firefox2.0,3.0和Inter ...

  9. Qt Creator构建并运行示例

    Qt Creator构建并运行示例 构建并运行示例 构建并运行示例 您可以通过打开现有的示例应用程序项目来测试Qt安装是否成功. 要在Android或iOS设备上运行示例应用程序,必须为Android ...

最新文章

  1. 配置jdk相关的记录
  2. 把LabelImg标注的YOLO格式标签转化为VOC格式标签 和 把VOC格式标签转化为YOLO格式标签
  3. @SuppressWarnings注解用法
  4. 如何改进yolov3_揭秘YOLOv3鲜为人知的关键细节
  5. MatLab GUI Change Size 改变界面大小
  6. 结对项目——个人博客
  7. Linux 配置vim编辑器
  8. 理解浏览器和nodeJs中的事件循环(Event Loop)
  9. python中%s是什么意思_python中的%s%是什么意思
  10. linux下echo /dev/ttys* 到字符设备文件,Linux系统的终端特殊设备文件
  11. 【编程题目】求1+2+…+n, 要求不能使用乘除法、for、while、if、else、switch、case和条件语句...
  12. 计算机打开查看方式默认是什么样,设置图片查看方式|两个设置图片默认打开方式方法...
  13. Sentaurus 入门之一安装教程
  14. 错误No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbala
  15. 外贸工具WhatsApp
  16. ubuntu vsftpd
  17. HTML5学堂,感谢您一年的陪伴(上)
  18. win7 android studio 升级HAXM后无法启动安卓模拟器
  19. linux系统下html工具,Linux下五个好用的HTML编缉器
  20. csv文件示例_自己动手? -一个简单的CSV解析器示例

热门文章

  1. XML——流机制解析器
  2. selenium自动化测试_49自动化测试中最常见的Selenium异常
  3. java 读取 文本块_Java 13:文本块
  4. oracle jdk_两个Oracle JDK的故事
  5. 参数化测试 junit_使用JUnit 5进行更清洁的参数化测试
  6. 响应式多级菜单 侧边菜单栏_使用纯HTML和OmniFaces构建动态响应的多级菜单
  7. Quarkus on OpenJ9 JVM和资源消耗
  8. java ee api_Java EE并发API教程
  9. js webapp://_Project Student:维护Webapp(只读)
  10. 带Spring Boot的GWT