CXF的一个很怪异的问题

ESB服务一直启动,使用动态调用CXF服务端方式,一直运行着的旧接口无任何问题,但是新加入注册表的服务(同一个WSDL地址新增operation)
就会报找不到operation, 察觉出一个规律,就是在JaxWsDynamicClientFactory createClient的时候,log4j会打印出Created classes: A,B,C,D,E。。。
等所有被调用的 WSDL地址 的operation的class生成情况,但是新增的operation就在 createClient调用时打印出来的 Created classes:里没出现

代码:
JaxWsDynamicClientFactory factory = JaxWsDynamicClientFactory
.newInstance();
Client c = factory.createClient("http://xx.xx.xx.xx:xx/path/ws/service?wsdl");



分析可能是ESB由于一直运行状态, createClient生成的东西存在于缓存内,createClient时候还是老的存根, 于是重启ESB观察, 果然出现了新增的operation的生成信息。。

问题虽暂时解决,但是不能一升级服务端 我这块就重启啊 而且 万一将来我不知道对方升级 当然不可能重启了

解决办法:
1.研究createClient内部生成机制
2.研究CXF的createClient是否有缓存机制
3.考虑更换方式,比如采用java.net.URL方式拼接报文传递文件,但是需要了解一下SOAP传递byte的格式




另外:
factory.createClient变态般的耗时,不知道采用memcached缓存起来是否可行。待实施

猜你喜欢

转载自zouruixin.iteye.com/blog/2065548