写点什么

用 Axis 2 提供异步式 Web Services

2007 年 12 月 17 日

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

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

关注

评论

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

【LeetCode】扁平化嵌套列表迭代器Java题解

HQ数字卡

算法 LeetCode 3月日更

下一站,星辰大海!

百度大脑

百度 AI 上市

Python 高手都这样使用字典,这些高效方法你知道吗?|pythonic 小技巧

AlwaysBeta

Python

SDK介绍及相关功能测试

行者AI

测试 sdk

不愧是阿里P7私传“并发编程核心讲义”,实战案例,个个是经典

周老师

Java 编程 程序员 架构 面试

Netty 核心源码解读 —— 开篇

然行

Netty

Netty 核心源码解读 —— ServerBootstrap 篇

然行

Netty

Rust从0到1-基础概念-变量

rust 变量

DB-Engines 3月数据库排名:MySQL跳出“同期跌幅榜”,拿下“本月涨幅榜冠军”

华章IT

数据库

nsq源码阅读之Channel

werben

golang nsq

超赞:不愧是“阿里内部Redis学习笔记”从头到尾,全是精华

周老师

Java 编程 程序员 架构 面试

MapReduce的运行机制详解

五分钟学大数据

大数据 mapreduce 3月日更

百度Feed稳定性架构实践

百度Geek说

解决方案 IDC feed

智慧公安重点人员系统开发,情报研判管控平台的搭建

13828808769

行业资讯

超全Android中高级面试复习大纲,在线面试指南

欢喜学安卓

android 程序员 面试 移动开发

使用Redis,你必须知道的21个注意要点

云流

Java 数据库 redis 架构 面试

nsq源码阅读之Topic

werben

golang nsq

nsq源码阅读之nsqd总体流程

werben

golang nsq

hive的DQL查询语法详细剖析

大数据技术指南

大数据 hive 3月日更

ACA世界大赛,赛前Live!金奖是怎么炼成的-公益创意作品剖析

Adobe国际认证

nsq源码阅读之消息接收和发送

werben

golang nsq

推荐35款可以快速提升工作效率的软件

科技猫

软件 经验分享 实用工具 办公 工具分享

Swift 5创建和使用Framework, XCFramework 从入门到精通 John 易筋 ARTS 打卡 Week 42

John(易筋)

ARTS 打卡计划 Framework XCFramework

SQLServer性能调优方法小结

嘉为蓝鲸

数据库 sql 运维 SqlServer MAXDOP

区块链BaaS应用平台的搭建,BaaS平台的应用场景

13828808769

#区块链#

想学IT的必看!漫谈MySQL权限安全,分享一点面试小经验

欢喜学安卓

android 程序员 面试 移动开发

Redis新版本开始引入多线程,谈谈你的看法?

Java架构师迁哥

已拿到蚂蚁金服Offer!阿里内部二十三万字Java面试题总结

Java架构追梦

Java 阿里巴巴 架构 面试题总结 金三银四

如何在3分钟内实现音频变声和趣味音效?

拍乐云Pano

音视频 RTC 音视频算法 出海社交 社交泛娱乐

阿里大牛全新整理!金三银四面试题库+Java全栈笔记限时开源

Java王路飞

Java 程序员 架构 面试

nsq源码阅读之diskqueue

werben

golang nsq

4月17日 HarmonyOS 开发者日·上海站

4月17日 HarmonyOS 开发者日·上海站

用Axis 2提供异步式Web Services-InfoQ