写点什么

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

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

关注

评论

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

使用kubernetes,你真的降本了吗

Geek_cd6rkj

Docker Kubernetes 云原生 成本治理 提效降本

开发者故事|朝九晚六大小周,我就是快乐的技术人

尔达Erda

程序员 云原生 经验分享 成长笔记 思考路径

RESAR 性能工程:一个性能项目真正体现价值的方式

zuozewei

内容合集 签约计划第二季

质量基础设施一站式服务平台建设,检验检测系统平台开发搭建

电微13828808271

CSS之选择器(七):empty

Augus

CSS 12月日更

基于社交网络的客户智能 ( AI ) 推荐系统研究

索信达控股

推荐系统 推荐算法 个性化推荐

埃文科技荣获“郑州市企业技术中心”

郑州埃文科技

埃文科技 ip技术 企业技术中心

黑客进行网络欺骗攻击的手段有哪些?

喀拉峻

黑客 网络安全 安全

【量化】用数据验证巴菲特推荐的指数定投的收益真相

恒生LIGHT云社区

数据 金融科技 量化投资 量化

西南林业大学:用宜搭打造智慧校园,节省百万费用

一只大光圈

钉钉 低代码 数字化 高校 钉钉宜搭

自身的强大,无惧任何威胁!

Tiger

28天写作

Istio在Rainbond Service Mesh体系下的落地实践

北京好雨科技有限公司

istio PaaS rainbond

RocketMQ和Kafka的差异对比

编程江湖

大数据

常见序列化算法学习笔记一

风翱

序列化 12月日更

哪些企业需要做等保测评?快速过等保测评用什么堡垒机好呢?

行云管家

网络安全 等保 等保测评 等保2.0

【实战】网络安全学习:内网渗透实例

网络安全学海

网络安全 信息安全 渗透测试 WEB安全 内网渗透

从0开始学VUE - 运行第一个VUE项目

恒生LIGHT云社区

JavaScript node.js Vue 前端

「Spark从精通到重新入门(二)」Spark中不可不知的动态资源分配

尔达Erda

大数据 spark 程序员 云原生 心得

企业数字化的4个痛点,低代码平台如何解决?

J2PaaS低代码平台

低代码 数字化 低代码平台

TDengine典型用户案例|内容合集

TDengine

tdengine 时序数据库 技术专题合集

英特尔深耕元宇宙算力技术,剑指开“元”盛世

科技新消息

利用Java反射处理private变量

FunTester

Java 工具 反射 Groovy FunTester

DotNet项目利用拦截器记录访问日志

为自己带盐

日志 dotnet 28天写作 12月日更

Rainbond 5.5 发布,支持Istio和扩展第三方Service Mesh框架

北京好雨科技有限公司

istio PaaS rainbond

14. 《重学JAVA》-- 内部类

杨鹏Geek

Java 25 周年 28天写作 12月日更

Linux一学就会之Linux计划任务与日志的管理

学神来啦

Linux centos 运维 SSH linux云计算

公安情报研判分析系统开发,情指勤一体化实战平台

电微13828808271

聚势聚能,共擎共飞 PKS安全先进计算2021生态大会将启

InfoQ 天津

低代码如何让中小型企业蓬勃发展?

低代码小观

低代码 企业管理系统 低代码平台 中小企业

云原生监控高可用集群 Thanos 架构剖析 | 内容合集

耳东@Erdong

内容合集 签约计划第二季

公安合成作战平台建设解决方案,情指勤一体化合成作战系统搭建

电微13828808271

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