设为首页 收藏本站
查看: 1182|回复: 0

[经验分享] Apache CXF 服务框架概览

[复制链接]

尚未签到

发表于 2017-1-3 12:12:47 | 显示全部楼层 |阅读模式
  1.CXF API
  CXF整体架构有以下部分组成:
  Bus: 包含这extensions, interceptors 和 Properties的注册。
  Front-end: Front-end: 规定了创建服务的编程模型
  Messaging & Interceptors:定义了低层级的message and pipeline层,绝大多数的功能都基于该层。
  Service Model:用来描述服务规范的,类似WSDL的服务模型来
  Pluggable Data Bindings:(后续祥说)
  Protocol Bindings:bindings提供了解释协议的功能
  Transports: Transportfactory 创建目的地(接受方)和输送出口(发送方)【Destinations (Receiving) and Conduits (Sending)】
  
DSC0000.png
  在下面这部分,我们将依次查看各层,并弄清楚他们如何一起协作的。
  1.1 BUS 
  CXF的中枢系统,CXF运行时共享资源的提供者。这些共享资源包括WSDL manager和binding factory manager。
  可以很容易将BUS共享的资源延伸到你自定义的资源或者服务,甚至替换掉默认的资源,如:用自定义HTTP destination factory (基于Tomcat的)的替换掉系统默认基于Jetty的HTTP destination factory 。
  扩展性使得依赖注入成为可能,默认的bus实现就是基于spring框架的。
  SpringBusFactory 会在你classpath下的META-INF/cxf 目录下搜索所有的bean配置文件。
  (BUS配置详见链接:BUS-Confuration)
  1.2 服务调用是如何处理。
  client-side
  
DSC0001.png
  server-side
  
DSC0002.png
  1.3 Front-ends
  Front-ends规定了与CXF交互通信的编程模型。
  现在CXF提供 JAX-WS, JAX-RS, Simple和Javascript 四种front-end的API。这四个实现的每一个都同CXF其他部分清爽的分隔开了。Front-end通过添加到Services 和 Endpoints的拦截器来提供自身的功能。
  1.4 Messaging & Interceptors
  CXF建立在Messages、Interceptors和InterceptorChains组成的一个普通消息层之上。拦截器Interceptor是功能的基本单元。消息的处理和发送功能的分离使得CXF的架构非常灵活,可以在消息处理的任何点上配置拦截器。这样CXF就有能力控制消息是终止或者者继续沿着拦截器链处理。
  拦截器通过方法handleMessagel在消息上执行一些操作。多个连接器可以构成拦截器链。
  拦截器是单向的并且他并不知晓自己所处理的是请求、还是响应,抑或错误。
  CXF提供的InterceptorChain实现叫做PhaseInterceptorChain。当拦截器被添加到链中的时候,他们就会被归类到有序的不同phase中。PhaseInterceptor将会管理同一个phase内部不同的拦截器间的顺序。
  错误处理
  在处理过程中,拦截器可能在任一个点抛出错误,这将导致整个链停止继续调用并且将会清理现场。清理现场操作一般是逆序在抛错前调用过的拦截器上调用handleFault方法。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-323282-1-1.html 上篇帖子: 安装apache时的配置 下篇帖子: apache配置虚拟主机(转载)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表