飞天发布时刻:2024年 Forrester 公有云平台Wave™评估报告解读 了解详情
写点什么

用 Axis 2 提供异步式 Web Services

  • 2007-12-17
  • 本文字数:1752 字

    阅读完需:约 6 分钟

Apache Web Services Wiki 上的 Stack Comparison (特性比较)表明,目前有 Apache 的 Axis 1.x、Axis2,Metro@GlassFish 和 Oracle Application Server 10g 提供了客户端异步交互和服务器端异步交互。

Apache Axis2 是一个开源的 Web Services 引擎,通过 Axis2,开发人员可以使用 Java 或 C 来调用或是实现 Web Services。Axis2 的一个核心特性就是可以提供同步式和异步式的交互, Rajith Attapattu 对此解释说:

为同步式和异步式交互提供支持,是 Web Services 的一个关键性需求,因为这二者都有着非常普遍的应用。Axis2 在传输层提供了这一特性,当请求到来后,可以通过同一种或是不同的传输方式来作出异步式响应。例如,如果一个请求通过 HTTP 到达,而后完成了异步式处理工作,最终的响应可以通过 HTTP 或是截然不同的传输方式——例如 JMS——返回。

Eran Chinthaka 的一篇名为“使用 Axis2 开发异步 Web Services(Develop asynchronous Web services with Axis2)”的文章中,提供了一些在客户端和服务器端应用中使用 Axis2 的异步 APIs 的示例。

在使用 Axis2 时,有两种方法可以异步式调用 Web Services。第一种方法是使用 Nonblocking API,

你可以为客户端提供一个 nonblocking API,这样它就可以把请求传递给 SOAP 引擎,继续做其他工作。客户端会提供一个回调对象,当 SOAP 引擎从服务器端收到响应时,就会通知这个回调对象。这种方式对使用 GUI 的交互式应用尤其有效。

Axis2 的早期版本中有一个叫做 Callback 的类,它可以被用来作为异步式消息的回调机制,或是一种轮询(polling)机制。这个类在 Axis2 1.3 中已经被废弃了,取而代之的是一个简单的接口—— AxisCallback 。藉由这个新的接口,开发人员可以实现 service 异步调用过程中的细粒度通知,但它并没有提供 Callback 类中的轮询机制。

在客户端异步式调用 Web Services 的第二种方法是在传输层实现的。Eran 描述了 Axis2 提供的传输方式,

所有可以用于 Web Services 调用中的传输方式可以大致分为两种:

  • 单向传输——提供发送或者接受消息的通道。
  • 双向传输——可以使用一个通道来发送和接收消息。

客户端在处理请求——响应的交互时,可以有多种选 择。最简单的一种就是用类似 HTTP 的双向传输。但是这种方式没有用到传输层的异步特性。客户端还可以使用两个单向传输或是两个双向传输。例如,你可以用 一个 SMTP 通道来发送消息,再用另外一个 SMTP 通道来接收消息。同时,你还可以用一个 HTTP 通道来发送请求,在消息发出后关闭通道,再使用另外一个 HTTP 通道来接受响应。但这就必须要有一种消息关联机制来使这种方式工作。Apache Axis2 使用了 WS-Addressing 规范来实现消息关联。

在 Axis2 中,用哪一种传输机制都变得非常简单,开发人员所需要做的就是在客户端通过设置 useSeparateListener 标记来使得双向传输可用。

Apache Axis2 在为客户端提供了异步式交互的同时,还提供了服务器端的异步式交互。标准的 SOAP 引擎通常只是在同一个线程中接受请求并做出响应。基于和客户端同样的原因,在服务器端提供异步式的处理并响应客户端请求也是大有益处的。

Axis2 用了一个消息接收器来负责处理 MEP,并把消息传送给对请求进行处理的逻辑或是服务实现。在一个同步调用中,消息接收 器会调用服务实现类(假设服务实现是用 Java 语言编写的)中的正确方法,然后在同一个线程中发送响应。但是在异步调用中,这个消息接收器会启动一个新的 线程来调用服务并向客户端发送通知。这个新的线程负责向客户端发送响应和从服务实现类中获取响应。

有两种方法可以很简单的在服务器端启用异步式交互,一种是在 WSDL 生成器中使用正确的标记,或是对 services.xml 进行配置,让它使用 AbstractInOutAsyncMessageReceiver 。 Eran Chinthaka 在文末总结说:

异步式调用给 Web Service 的用户或是编写并托管 Web Services 的人提供了很大的灵活性。越来越多的 Web Services 变得更加通用,更加复杂,也有越来越多的应用程序把这些 Web Services 集成到自己的应用中去。因为大多数最终应用基本上都需要和用户交互,所以如何提高用户体验就成了重中之重。在多种层次上——客户端和服务 器端——提供异步式的 Web Services 调用,可以帮助我们加深对这些目前面临的挑战的认识。

查看英文原文 Using Axis2 for Asynchronous Web Services

2007-12-17 00:452712
用户头像

发布了 197 篇内容, 共 57.1 次阅读, 收获喜欢 20 次。

关注

评论

发布
暂无评论
发现更多内容

Week1命题作业

星河寒水

部署图 时序图 组件图 用例图

第一章作业

李白

人工智能之机械基

码农神说

人工智能 程序员 加班

食堂就餐卡系统设计

Linkin

架构师成长心得

熊威

架构作业-UML图

铁血杰克

食堂就餐卡系统设计

Thrine

第一章作业-学习总结

李白

食堂就餐卡系统设计

慢慢来的比较快

孤狼王兴 | 互联网大佬往事

刘燕

AI 企业管理 美团

【架构思维学习】week01

chun1123

软件架构 UML

第一周学习总结

Thrine

2020年6月10日 异常、断言和日志

瑞克与莫迪

食堂就餐卡系统设计

Young

架构师 week 1 作业一

iLeGeND

作业二:根据当周学习情况,完成一篇学习总结

晨光

第一周学习总结

Young

作业一:食堂就餐卡系统设计

晨光

【架构师训练营】1 - 食堂就餐卡系统设计

悬浮

架构 UML 部署图

UML用例图组件图部署图

熊威

作业一:食堂就餐卡系统设计

证明谁才是第一

食堂就餐卡 最用心

学习总结--Week1

吴炳华

极客大学架构师训练营

食堂就餐卡系统设计(第一周作业)

Geek_237932

架构师如何做架构-开篇

铁血杰克

架构师和软件架构的理解

周冬辉

Week 01 学习总结:UML图

鱼_XueTr

week1学习总结

慢慢来的比较快

架构师训练营 第一周 学习总结

RZC

【架构思维-学习总结】week01

chun1123

学习 架构 思维方式

GitHub 热榜:轻量级无 Agent 的自动化运维平台!

JackTian

GitHub 开源 spug 运维自动化 监控管理平台

架构师训练营 第一周 命题作业

RZC

用Axis 2提供异步式Web Services_Java_Craig Wickesser_InfoQ精选文章