我在apache camel中构建了一个web服务,作为karaf上的一个包运行,它接收请求并将信息保存在数据库中。
在此之后,另一个bundle获取此插入的记录,修改数据并将其保存回db。
现在我需要原始请求的响应来包含修改后的数据,所以除了看起来像这样的Web服务的路由
<route id="cxf">
<from uri="cxf:bean:getHopEndpoint" />
<recipientList>
<simple>direct:${header.operationName}</simple>
</recipientList>
</route>
<route id="getHop">
<from uri="direct:getHop" />
<process ref="getHopToDbProcessor" />
<to
uri="sql:INSERT INTO myTable (field1, field2) VALUES (:#field1, :#field2)"/>
</route>
我需要另一个这样的
<route id="cxfResponse">
<from uri="sql:SELECT * FROM myTable"/>
<!-- to web service response in any way -->
</route>
有没有办法做到这一点?
答案 0 :(得分:1)
您必须将主体设置为所需的响应,作为第一个路径中的最后一步。无法在此路线之外设置响应。
所以我认为有两种方法可以解决你的问题。
对于Variant 2,您既可以使用jms之类的消息,也可以先拨打一个webservice uri来回拨。
如果您对服务的负载很高,那么完全异步的方法可能会使您的系统更好地工作。
答案 1 :(得分:1)
我找到了另一个解决方案:我正在使用Direct VM Component。我的路线现在看起来像这样:
Bundle 1接收Web服务请求并将数据保存在数据库中:
<route id="cxf">
<from uri="cxf:bean:getHopEndpoint" />
<recipientList>
<simple>direct:${header.operationName}</simple>
</recipientList>
</route>
<route id="getHop">
<from uri="direct:getHop" />
<process ref="getHopToDbProcessor" />
<to uri="sql:INSERT INTO myTable (field1, field2) VALUES (:#field1, :#field2)" />
<to uri="direct-vm:processHop" />
</route>
在bundle 2中处理我刚刚插入的数据:
<route>
<from uri="direct-vm:processHop"/>
<to uri="sql:SELECT * FROM myTable WHERE processed = false" />
<process ref="getHopComputopUrlProcessor" />
<to uri="sql:UPDATE webshop_gethop_requests SET new_data = :#newData, processed = true WHERE some_id = :#someId" />
<to uri="direct-vm:response"/>
</route>
然后再回到捆绑1以发送带有已处理数据的响应:
<route>
<from uri="direct-vm:response" />
<to uri="sql:SELECT some_id,new_data FROM myTable WHERE some_id = :#someId AND processed = true" />
<process ref="getHopResponseProcessor" />
</route>
这对我来说很好用:):