- 浏览: 207005 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
maxrocray:
现在没管用的了。。。
google的IP地址列表 -
greenwen:
谢谢您的分析,学习受教了
几种通讯协议的比较 -
chaiying:
...
几种通讯协议的比较 -
liyan12167:
哥们 我想向您请教些更详细的内容 不知道你还会在上线不 上来 ...
什么是SyncML -
追求幸福:
...
SyncML相关资源链接
概要介绍
在我们的项目中,特别是在J2EE分布式系统中,我们经常需要选择某种远程服务协议,在分布的进程间来进行交互和系统数据调用。目前可供选择的协议 EJB、 基于SOAP的Web Service 这些都是重量级的,也有像RMI、Socket这样的比较原始的。但是Hessian/burlap/HttpInvoker是比较优秀的,也曾在多个项目和工程中使用,性能比较好,也比较稳定,如阿里巴巴(北京-杭州)和淘宝内部(杭州-北京)的对象交互都是采用这种方法。实践证明,传输同样的对象,Hessian协议传输的数据量比SOAP协议低一个数量级。因此在复杂网络环境下的分布式应用使用Hessian协议可以获得更好的性能和可靠性。
Hessian和Burlap是由Caucho公司提供的方案,如果把Hessian/Burlap与Spring结合使用,设计者将感到无比的方便。Spring目前提供了对RMI、HttpInvoker、Hessian、Burlap及WebService等Remoting技术的集成。而Spring又是目前业务逻辑层常用的框架,因此采用在spring中使用Hessian来传输二进制流是符合开发效果和成本的。Hessian/Burlap/HttpInvoker将参数和返回值通过Java的序列化机制进行编组和反编组,它具有RMI的支持所有可序列化对象的优点。是使用Http协议传输二进制流的,Hessian的binary协议和web service常用的SOAP协议类似,也是将协议报文封装在HTTP封包中,通过HTTP信道传输的。因此Hessian协议具有与SOAP协议同样的优点,即传输不受防火墙的限制(防火墙通常不限制HTTP信道)。Hessian和Burlap解决了RMI头疼的防火墙问题。并且它们都是非常轻量级的,足以在内存或空间受限制的环境下使用,例如applet和无线设备。下面看一下几种基于HTTP协议的RPC性能比较(来源网上):
l Axis ---------->> Total time: 87359 ms, Avg time: 8.7359 ms
l Burlap --------->> Total time: 5784 ms, Avg time: 0.5784 ms
l Hessian -------->> Total time: 5084 ms, Avg time: 0.5084 ms
l REST ---------->> Total time: 7983 ms, Avg time: 0.7983 ms
l AxisUsingWSDL2Java ->> Total time: 113234 ms, Avg time: 11.3234 ms
从中可以看出,在相同的环境下Hessian具有非凡的性能和表现。
下面我们来看一下一个真实的Demo和开发步骤。
开发环境:
Myeclipse6.5和JDK1.6、Spring 2.5和Resin3.13
一.Server端的开发及服务发布
1.创建工程及代码类
建立一个web project,我取名为APIServer,创建包及包名和我们要开放服务器的接口及实现类。
接口很简单,就是返回用户对象的List。(假如这个server要提供用户信息给远程系统或者服务)
public interface DemoService {
List<SyncObject> getUsers();
}
上面接口的实现:
public class DemoServiceImpl implements DemoService {
public List<SyncObject> getUsers(){
//可以从数据库查询或者文件获取所需的数据进行封装
//此处为了测试写死一些数据。
List<SyncObject> lis = new ArrayList();
SyncObject user1 = new SyncObject();
SyncObject user2 = new SyncObject();
user1.setUsername("username1 from server");
user1.setPassword("password1 from server");
user2.setUsername("username2 from server");
user2.setPassword("password2 from server");
lis.add(user1);
lis.add(user2);
return lis;
}
}
2.配置文件信息
配置web.xml
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>
<!-- web container把所有的请求都交给DispatcherServlet -->
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<!-- 所有匹配/remoting/*的请求被DispatcherServlet 截获-->
<servlet-name>dispatcher</servlet-name>
<url-pattern>/remote/*</url-pattern>
</servlet-mapping>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log4j.properties</param-value>
</context-param>
<listener>
<listener-class>
com.sitech.vasd.server.servlet.SystemConfigListener
</listener-class>
</listener>
配置dispatcher-servlet.xml
<!-- 业务类 -->
<bean id="demoService" class="com.demo.api.server.DemoServiceImpl" />
<!-- 远程服务 -->
<!-- 使用HessianServiceExporter 将普通bean导出成Hessian服务-->
<bean name="/HessianService" class="org.springframework.remoting.caucho.HessianServiceExporter">
<!-- 需要导出的目标bean-->
<property name="service" ref="demoService" />
<!-- Hessian服务的接口-->
评论
发表评论
-
session 处理2种方式
2010-01-21 17:25 1435随着互联网的日益壮大,网站的pv和uv成线性或者指数倍的增加. ... -
异质数据结构
2009-11-21 12:28 1470堆栈、队列、链表等数据结构中的数据通常都是单一类型 ... -
Java获取代理客户端真实IP地址
2009-09-11 18:06 1939在JSP里,获取客户端的IP地址的方法是:request.ge ... -
杂论架构
2009-09-07 09:16 1075一、架构的含义 许多人对什么是架构或者架构设计包含什么内容比 ... -
nginx后面的jboss获取不到真实IP解决方案
2009-07-24 11:01 4220nginx+(1…n)tomcat集群部署时,后端tomcat ... -
byte short int long float double
2009-07-22 17:58 1532byte: 八位整数 -128——127,可用来节省内存的使用 ... -
架构思想
2009-06-26 10:15 1049一 架构思想 1.1 HTML页 ... -
jboss 4.22 优化心得
2009-01-16 13:39 1199增大可使用内存,修改bin/run.sh文件 JAVA_OPT ... -
JBoss 5.0 安装配置负载均衡
2009-01-14 17:39 5964简明JBOSS 5的安装配置说明 环境为Linux AS ... -
基于Hessian的高性能远程对象调用的服务器端和客户端的Demo 2
2008-12-31 10:52 1501<!-- Hessian服务的接口--> &l ... -
剔除List中的重复值
2008-08-28 22:34 1954方法一:循环元素删除 // 删除ArrayList中重复 ... -
spring 2.5 mvc annotation使用
2008-06-11 11:16 2731项目中一种在用spring2.0,虽然2.5出来了很多新特性, ... -
webwork2中文参考手册.pdf
2008-05-11 22:54 1874webwork2中文参考手册.pdf -
Spring-MVC-step-by-step2.rar
2008-05-11 22:51 926Spring-MVC-step-by-step2.pdf -
学习Spring
2008-05-08 11:58 12741、如何学习Spring? ... -
基于Spring技术应用的远程服务
2008-05-08 11:04 956来源:赛迪网 一.引言 从根本上分析,Remoting实 ... -
几种通讯协议的比较
2008-05-08 10:54 8237一、综述 本文比较了RMI,Hessian,Burlap,Ht ... -
webwork之HelloWorld篇
2008-04-29 15:20 1361任何结果都是由简单的实践得出的,当然我下面的介绍也是模仿那些大 ... -
JDK1.5中的线程池使用简介
2008-04-25 17:49 2818学习 JDK1.5中的线程池使用简介 ... -
jboss 启动时java.sql.SQLException: User not found: SA
2008-04-03 17:11 2516修改下面的文件: jboss-4.0.3\server\def ...
相关推荐
综上所述,"hessian 服务器 客户端 demo"是一个演示如何使用Hessian协议实现服务器和客户端之间的RPC通信的示例。这个压缩包可能包含了服务器和客户端的代码实现,帮助开发者了解和学习如何在实际项目中应用Hessian...
6. **调用远程方法**:通过代理对象调用服务端的方法,就像调用本地方法一样。 **标签中的“hessian”和“java”**表明这是关于Java平台上的Hessian技术。Hessian是跨语言的,但在这个例子中,我们专注于Java环境下...
在本项目中,我们探讨的是基于C#实现的Hessian服务端和客户端,已经在IIS环境下进行了测试并成功通过。 1. **Hessian协议**:Hessian是由Caucho公司开发的一种轻量级、高效的二进制协议,主要用于Web服务。它支持...
本教程将详细介绍"Hessian远程调用RPC最简单demo",包括服务器端服务发布和客户端服务调用的实现,以及所需资源。 首先,我们来看一下`hessian-4.0.7.jar`这个文件。这是Hessian库的核心组件,包含了实现Hessian...
- **配置详解**:文档通常会包含如何配置Hessian服务端和客户端的详细步骤,例如设置服务器端的监听端口,客户端的连接参数等。 - **示例代码**:提供服务端和服务端的代码示例,展示如何创建、注册服务以及如何...
Hessian二进制Web服务协议(Hessian Binary Web Service Protocol)是一种高效的、轻量级的远程过程调用(RPC)协议,它主要用于提高Web服务之间的通信效率。Hessian由Caucho Technology公司开发,旨在解决XML-RPC在...
在IT行业中,远程调用是一种常见的技术,使得客户端可以跨网络调用远程服务器上的方法,就像调用本地方法一样方便。Hessian是Apache项目下的一个轻量级的RPC(Remote Procedure Call,远程过程调用)框架,它提供了...
5. **调用服务**:一旦连接建立,客户端就可以像调用本地对象一样调用远程服务的方法,Hessian会自动处理网络传输和数据类型转换。 6. **处理响应**:服务器端执行完方法后,将结果返回给客户端,Hessian会将结果反...
Hessian远程调用框架是基于Java的轻量级RPC(Remote Procedure Call)解决方案,它允许开发者在分布式系统中实现高效、便捷的跨网络对象方法调用。本教程将引导你入门Hessian,通过一个简单的JAVA demo来理解其工作...
这涉及到客户端发送一个包含方法名和参数的序列化请求,服务器端接收到请求后解序列化,执行相应的方法,并将结果反序列化回客户端。 现在,让我们深入到这个"简单demo"的细节。在这个例子中,我们可能会看到以下...
Hessian库会自动处理序列化和反序列化,使得客户端可以像调用本地方法一样调用远程服务。 3. **PHP客户端** (`php-client.rar`): - PHP客户端同样利用Hessian协议来调用Java服务器上的服务。 - PHP中,你可以...
2. 使用工厂生成服务接口的代理对象,这个对象可以像调用本地方法一样调用远程服务。 3. 执行远程调用,结果会自动反序列化为Java对象。 四、Hessian与其他远程调用框架的比较: 1. **RMI**:Java原生的RMI使用...
- 客户端代码可以通过Spring的依赖注入获取服务代理,然后像调用本地方法一样调用远程服务。 3. **运行与测试:** - 启动Jetty服务器,加载Spring上下文,启动Hessian服务。 - 客户端通过HTTP调用Hessian服务,...
Spring会自动创建代理对象,使得客户端可以通过这个代理对象调用远程服务的方法,就像调用本地对象一样。 3. **使用源码分析**: Hessian库提供了`HessianProxyFactoryBean`和`HessianServiceExporter`这两个关键...
【描述】提供的教程包含了服务器端和客户端的实例代码,这两个例子旨在帮助开发者快速理解和应用Hessian。它们非常直观,可以直接运行,无需复杂配置,从而让你对Hessian的工作原理有深刻的理解。 首先,我们来了解...
开发者通常会使用Hessian库来实现客户端和服务端之间的通信,使得Android应用可以调用远程服务端的方法,就像调用本地方法一样方便。 3. **Hessian库的集成**:在Android项目中,需要引入支持Android的Hessian库,...
通过这个示例,你可以深入理解如何在Java环境中搭建和使用Hessian服务,以及如何在客户端进行远程调用,这对于理解和应用RPC技术是非常有价值的。同时,这也展示了Hessian在实现高效、轻量级的分布式系统中的潜力。
1. 什么是 rpc RPC 全称为 Remote Procedure Call,翻译过来为 “远程过程调用”。 目前,主流的平台中都支持各种远程调用技术,以满足...RPC 在使用形式上像调用本地函数(或方法)一样去调用远程的函数(或方法)。
在服务器端,通过HessianServlet来暴露这个服务,客户端则通过HessianProxyFactory来创建服务代理,从而能够调用远程服务的方法。这种简单设置可以让开发者快速理解Hessian的基本工作原理。 二、Hessian与Spring...