apache synapse使用(2)

简介:

接着上面看官方的示例

消息中介示例

1,本地注册项,可重复使用的端点和序列

<!-- Local Registry entry definitions, reusable endpoints and sequences -->
< definitions  xmlns="http://ws.apache.org/ns/synapse"
              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     <!-- define a string resource entry to the local registry -->
     < localEntry  key="version">0.1</ localEntry >
     <!-- define a reuseable endpoint definition -->
     < endpoint  name="simple">
         < address  uri="http://localhost:9000/services/SimpleStockQuoteService"/>
     </ endpoint >
 
     <!-- define a reusable sequence -->
     < sequence  name="stockquote">
         <!-- log the message using the custom log level. illustrates custom properties for log -->
         < log  level="custom">
             < property  name="Text" value="Sending quote request"/>
             < property  name="version" expression="get-property('version')"/>
             < property  name="direction" expression="get-property('direction')"/>
         </ log >
         <!-- send message to real endpoint referenced by key "simple" endpoint definition -->
         < send >
             < endpoint  key="simple"/>
         </ send >
     </ sequence >
 
     < sequence  name="main">
         < in >
             < property  name="direction" value="incoming"/>
             < sequence  key="stockquote"/>
         </ in >
         < out >
             < send />
         </ out >
     </ sequence >
</ definitions >

客户端执行

ant stockquote -Daddurl=http://localhost:9000/services/SimpleStockQuoteService -Dtrpurl=http://localhost:8280/

 可以看到输出的结果

 Standard :: Stock price = $80.1611906447455

过程是先进入main然后直接进入可重用序列stockqnote,最后将请求的信息发送到http://localhost:9000/services/SimpleStockQuoteService

使用http://localhost:9000/services/SimpleStockQuoteService?wsdl可以看到显示的结果

 

2,错误处理

< definitions  xmlns="http://ws.apache.org/ns/synapse"
              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 
     <!-- the default fault handling sequence used by Synapse - named 'fault' -->
     < sequence  name="fault">
         < log  level="custom">
             < property  name="text" value="An unexpected error occured"/>
             < property  name="message" expression="get-property('ERROR_MESSAGE')"/>
         </ log >
         < drop />
     </ sequence >
 
     < sequence  name="sunErrorHandler">
         < log  level="custom">
             < property  name="text" value="An unexpected error occured for stock SUN"/>
             < property  name="message" expression="get-property('ERROR_MESSAGE')"/>
             <!--<property name="detail" expression="get-property('ERROR_DETAIL')"/>-->
         </ log >
         < drop />
     </ sequence >
 
     < sequence  name="main">
         < in >
             < switch  xmlns:m0="http://services.samples" source="//m0:getQuote/m0:request/m0:symbol">
                 < case  regex="IBM">
                     < send >
                         < endpoint >
                             < address  uri="http://localhost:9000/services/SimpleStockQuoteService"/>
                         </ endpoint >
                     </ send >
                 </ case >
                 < case  regex="MSFT">
                     < send >
                         < endpoint  key="bogus"/>
                     </ send >
                 </ case >
                 < case  regex="SUN">
                     < sequence  key="sunSequence"/>
                 </ case >
             </ switch >
             < drop />
         </ in >
 
         < out >
             < send />
         </ out >
     </ sequence >
 
     < sequence  name="sunSequence" onError="sunErrorHandler">
         < send >
             < endpoint  key="sunPort"/>
         </ send >
     </ sequence >
 
</ definitions >

 客户端执行

ant stockquote -Daddurl=http://localhost:9000/services/SimpleStockQuoteService -Dtrpurl=http://localhost:8280/ -Dsymbol=MSFT

执行查询MSFT的股价,因为没有对应的端点查找最接近的错误处理,服务端看到提示

INFO LogMediator text = An unexpected error occured, message = Couldn't find the endpoint with the key : bogus

执行查看sun的股价

ant stockquote -Daddurl=http://localhost:9000/services/SimpleStockQuoteService -Dtrpurl=http://localhost:8280/ -Dsymbol=SUN

最后打印出信息

INFO LogMediator text = An unexpected error occured for stock SUN, message = Couldn't find the endpoint with the key : sunPort

这个是在sunSeqence这个序列里执行的。

 

3,创建错误的SOAP信息并且变化消息的方向

<!-- Creating SOAP fault messages and changing the direction of a message -->
< definitions  xmlns="http://ws.apache.org/ns/synapse"
              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 
     < sequence  name="myFaultHandler">
         < makefault  response="true">
             < code  xmlns:tns="http://www.w3.org/2003/05/soap-envelope" value="tns:Receiver"/>
             < reason  expression="get-property('ERROR_MESSAGE')"/>
         </ makefault >
         < send />
     </ sequence >
 
     < sequence  name="main" onError="myFaultHandler">
         < in >
             < switch  xmlns:m0="http://services.samples" source="//m0:getQuote/m0:request/m0:symbol">
                 < case  regex="MSFT">
                     < send >
                         < endpoint >
                             < address  uri="http://bogus:9000/services/NonExistentStockQuoteService"/>
                         </ endpoint >
                     </ send >
                 </ case >
                 < case  regex="SUN">
                     < send >
                         < endpoint >
                             < address  uri="http://localhost:9009/services/NonExistentStockQuoteService"/>
                         </ endpoint >
                     </ send >
                 </ case >
             </ switch >
             < drop />
         </ in >
 
         < out >
             < send />
         </ out >
     </ sequence >
 
</ definitions >

 客户端调用

ant stockquote -Daddurl=http://localhost:9000/services/SimpleStockQuoteService -Dtrpurl=http://localhost:8280/ -Dsymbol=MSFT

 返回

<soapenv:Fault xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"><faultcode>soapenv:Client</faultcode> <faultstring>java.net.UnknownHostException: bogus</faultstring><detail /></soapenv:Fault>

执行

ant stockquote -Daddurl=http://localhost:9000/services/SimpleStockQuoteService -Dtrpurl=http://localhost:8280/ -Dsymbol=SUN

返回

<soapenv:Fault xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"><faultcode>soapenv:Client</faultcode> <faultstring>java.net.ConnectException: Connection refused</faultstring><detail /></soapenv:Fault>

 

4,操纵SOAP协议头,修改传入或传出的消息

<!-- Manipulating SOAP headers, and filtering incoming and outgoing messages -->
< definitions  xmlns="http://ws.apache.org/ns/synapse"
              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 
     < sequence  name="main">
         < in >
             < header  name="To" value="http://localhost:9000/services/SimpleStockQuoteService"/>
         </ in >
         < send />
     </ sequence >
 
</ definitions >

 修改协议头

客户端调用

ant stockquote -Dtrpurl=http://localhost:8280/

直接指向

目录
相关文章
|
监控 Java Apache
apache synapse使用(1)
一.Synapse介绍 Synapse 是一个简单的 XML 和 Web 服务管理与集成代理,可用于构成 SOA 和企业服务总线(ESB)的基础。Synapse是 Web 服务项目中一项成熟的 Apache 活动,并且是非常成功的 Apache Axis2 项目的一个分支。
844 0
|
6月前
|
存储 消息中间件 Java
Apache Flink 实践问题之原生TM UI日志问题如何解决
Apache Flink 实践问题之原生TM UI日志问题如何解决
64 1
|
2月前
|
存储 人工智能 大数据
The Past, Present and Future of Apache Flink
本文整理自阿里云开源大数据负责人王峰(莫问)在 Flink Forward Asia 2024 上海站主论坛开场的分享,今年正值 Flink 开源项目诞生的第 10 周年,借此时机,王峰回顾了 Flink 在过去 10 年的发展历程以及 Flink社区当前最新的技术成果,最后展望下一个十年 Flink 路向何方。
414 33
The Past, Present and Future of Apache Flink
|
4月前
|
SQL Java API
Apache Flink 2.0-preview released
Apache Flink 社区正积极筹备 Flink 2.0 的发布,这是自 Flink 1.0 发布以来的首个重大更新。Flink 2.0 将引入多项激动人心的功能和改进,包括存算分离状态管理、物化表、批作业自适应执行等,同时也包含了一些不兼容的变更。目前提供的预览版旨在让用户提前尝试新功能并收集反馈,但不建议在生产环境中使用。
1054 13
Apache Flink 2.0-preview released
|
4月前
|
存储 缓存 算法
分布式锁服务深度解析:以Apache Flink的Checkpointing机制为例
【10月更文挑战第7天】在分布式系统中,多个进程或节点可能需要同时访问和操作共享资源。为了确保数据的一致性和系统的稳定性,我们需要一种机制来协调这些进程或节点的访问,避免并发冲突和竞态条件。分布式锁服务正是为此而生的一种解决方案。它通过在网络环境中实现锁机制,确保同一时间只有一个进程或节点能够访问和操作共享资源。
182 3
|
5月前
|
SQL 消息中间件 关系型数据库
Apache Doris Flink Connector 24.0.0 版本正式发布
该版本新增了对 Flink 1.20 的支持,并支持通过 Arrow Flight SQL 高速读取 Doris 中数据。
|
6月前
|
消息中间件 监控 数据挖掘
基于RabbitMQ与Apache Flink构建实时分析系统
【8月更文第28天】本文将介绍如何利用RabbitMQ作为数据源,结合Apache Flink进行实时数据分析。我们将构建一个简单的实时分析系统,该系统能够接收来自不同来源的数据,对数据进行实时处理,并将结果输出到另一个队列或存储系统中。
410 2
|
6月前
|
消息中间件 分布式计算 Hadoop
Apache Flink 实践问题之Flume与Hadoop之间的物理墙问题如何解决
Apache Flink 实践问题之Flume与Hadoop之间的物理墙问题如何解决
81 3
|
6月前
|
消息中间件 运维 Kafka
Apache Flink 实践问题之达到网卡的最大速度如何解决
Apache Flink 实践问题之达到网卡的最大速度如何解决
74 2
|
6月前
|
消息中间件 前端开发 Kafka
【Azure 事件中心】使用Apache Flink 连接 Event Hubs 出错 Kafka error: No resolvable bootstrap urls
【Azure 事件中心】使用Apache Flink 连接 Event Hubs 出错 Kafka error: No resolvable bootstrap urls
106 2

热门文章

最新文章

推荐镜像

更多