在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

用 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:453084
用户头像

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

关注

评论

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

冰泉奶茶香牙膏好不好?奶茶控的宝藏牙膏就是它

Geek_50a546

30分钟接入SDK 融云是如何让开发者做到开箱即用的?

融云 RongCloud

面试官:你知道怎么求素数吗?

华为云开发者联盟

面试 开发者 开发 代码 素数

AI如何赋能软硬件产品创新?百度大脑开放日西安站解密

百度大脑

AI 百度大脑 开放日 EdgeBoard

拥抱开放的英特尔 让PC行业再次越过创新鸿沟

E科讯

代码管理工具:Git和SVN

正向成长

git svn

爆赞:这份Github神仙面试笔记,不愧是上了标星120k+的Java面试手册

Java 编程 程序员 架构 面试

12种mysql常见错误总结 +分析示例

李阿柯

MySQL 面试 常见问题

为什么switch的case没有break不行

叫我阿柒啊

Switch case break

HarmonyOS学习路之开发篇——公共事件与通知(一)

爱吃土豆丝的打工人

Java HarmonyOS 鸿蒙操作系统

回忆录 | 那些你不能错过的CTF夏令营往届历程,2021精彩继续……

郑州埃文科技

🏆「作者推荐」【JVM原理探索】深入理解G1垃圾收集器的原理和运行机制

码界西柚

G1 JVM 6月日更 垃圾回收器

计算机网络的 89 个核心概念

苹果看辽宁体育

后端 计算机网络 网络

深度解读MRS IoTDB时序数据库的整体架构设计与实现

华为云开发者联盟

大数据 架构 时序数据库 FusionInsight MRS MRS IoTDB

掌门教育自研APM实际分享

白玉兰开源

联想服务斩获两项智能运维大奖 助力企业业务创新与数字化转型

科技大数据

神经网络吴恩达, 解析极限编程--Kent Beck, Cynthia Andres John 易筋 ARTS 打卡 Week 53

John(易筋)

ARTS 打卡计划

JAVA 面向对象 (十四)-- 关键字abstract、final

加百利

6月日更

CentOS7 Linux服务器无法远程ssh登陆故障处理

Liyuanjie

Centos 7 linux运维 Linux内核

[译] D8 类库脱糖

Antway

6月日更

从零开始学习3D可视化之事件绑定

ThingJS数字孪生引擎

大前端 物联网 3D 3D可视化

数据结构——顺序表

若尘

数据结构 6月日更

AI论文解读:基于Transformer的多目标跟踪方法TrackFormer

华为云开发者联盟

预测 Transformer 多目标跟踪 TrackFormer 跟踪目标

容器化 | 在 Kubernetes 上部署 RadonDB MySQL 集群

RadonDB

MySQL Kubernetes 容器

带你认识9种常用卷积神经网络

华为云开发者联盟

神经网络 深度学习 卷积神经网络 图像 卷积

基于 Web 引擎扩展技术的 RTC 混合开发框架实践

白玉兰开源

大前端

可视化搭建的一些思考和实践

白玉兰开源

Rust从0到1-自动化测试-测试组织

rust 单元测试 集成测试 自动化测试

使用 Scala 宏解决对象转换

GrowingIO技术专栏

scala protobuf 元编程 macro

支持低代码开发和远程真机,DevEco Studio 2.2 Beta1来啦

科技汇

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