`
dalezhu
  • 浏览: 210405 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

基于Hessian的高性能远程对象调用的服务器端和客户端的Demo

    博客分类:
  • Java
阅读更多

概要介绍

在我们的项目中,特别是在J2EE分布式系统中,我们经常需要选择某种远程服务协议,在分布的进程间来进行交互和系统数据调用。目前可供选择的协议 EJB 基于SOAPWeb Service 这些都是重量级的,也有像RMISocket这样的比较原始的。但是Hessian/burlap/HttpInvoker是比较优秀的,也曾在多个项目和工程中使用,性能比较好,也比较稳定,如阿里巴巴(北京-杭州)和淘宝内部(杭州-北京)的对象交互都是采用这种方法。实践证明,传输同样的对象,Hessian协议传输的数据量比SOAP协议低一个数量级。因此在复杂网络环境下的分布式应用使用Hessian协议可以获得更好的性能和可靠性。

HessianBurlap是由Caucho公司提供的方案,如果把Hessian/BurlapSpring结合使用,设计者将感到无比的方便。Spring目前提供了对RMIHttpInvokerHessianBurlapWebServiceRemoting技术的集成。而Spring又是目前业务逻辑层常用的框架,因此采用在spring中使用Hessian来传输二进制流是符合开发效果和成本的。Hessian/Burlap/HttpInvoker将参数和返回值通过Java的序列化机制进行编组和反编组,它具有RMI的支持所有可序列化对象的优点。是使用Http协议传输二进制流的,Hessianbinary协议和web service常用的SOAP协议类似,也是将协议报文封装在HTTP封包中,通过HTTP信道传输的。因此Hessian协议具有与SOAP协议同样的优点,即传输不受防火墙的限制(防火墙通常不限制HTTP信道)HessianBurlap解决了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.5JDK1.6Spring 2.5Resin3.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服务的接口-->

 

 

分享到:
评论
1 楼 ruiyang86 2009-03-19  
不知道这样行不行,以前我都是传字符串,拼接了好长的字符串,走到服务器端还有分解,处理空的情况,特别麻烦,要是这样能传对象的化,就太好了,有时间测试一下!

相关推荐

    Hessian学习简单demo

    这涉及到客户端发送一个包含方法名和参数的序列化请求,服务器端接收到请求后解序列化,执行相应的方法,并将结果反序列化回客户端。 现在,让我们深入到这个"简单demo"的细节。在这个例子中,我们可能会看到以下...

    hessian+spring小案例

    - 在客户端,也需要创建与服务器端相同的接口及User类,并通过HessianProxyFactory来创建远程代理对象。 ```java HessianProxyFactory factory = new HessianProxyFactory(); DemoApi demoApi = (DemoApi) ...

    CXF+RMI+HESSIAN

    然后,Hessian作为CXF和客户端之间的通信协议,提供高效的远程调用。这种组合特别适用于内部网络环境,因为它减少了数据传输的开销,提高了服务调用的响应速度。 在实际应用中,我们可能需要以下步骤来实现“CXF+...

    Hessian的demo

    Hessian是由Caucho Technology开发的一种轻量级的远程过程调用(RPC)协议,它主要设计用于Web服务。与传统的基于XML的SOAP协议相比,Hessian更加高效,因为它是二进制格式,数据传输量小,解析速度快。这使得...

    springboot-httpinvoker-demo.zip

    HTTP Invoker是Spring框架提供的一个基于HTTP协议的远程调用机制,它通过序列化对象并将其作为HTTP请求的body发送到远程服务器,然后由服务器反序列化并执行相应的方法。这种方式相比于传统的RMI或者Hessian,更加...

    dubbo 使用基本功能demo

    在IT行业中,Dubbo是一款非常著名的高性能、轻量级的Java RPC框架,它由阿里巴巴开源并在社区中得到了广泛的应用和持续的发展。这个“dubbo 使用基本功能demo”项目旨在通过一个简单的实例,帮助开发者理解并掌握...

    dubbo案列demo代码

    【标题】"Dubbo案例Demo代码"涉及到的核心技术是Dubbo,它是一个高性能、轻量级的开源Java RPC框架,由阿里巴巴开发并贡献给Apache基金会。Dubbo的主要目的是解决分布式系统中的服务调用问题,提高服务的可扩展性和...

    zookeeper+rpc学习demo

    在IT行业中,分布式系统是大型应用...总结来说,Zookeeper和RPC在Java分布式开发中扮演了重要角色,理解并掌握这两者有助于构建高可用、高性能的分布式系统。通过学习和实践,你可以进一步提升在分布式领域的技术水平。

    rpc-package:模仿dubbo实现的一个rpc框架demo,仅仅用来说明底层原理

    1. **服务接口定义**: 应该包含服务提供者和消费者共同遵循的服务接口,这些接口定义了可以被远程调用的方法。 2. **服务暴露**: 实现服务提供者将服务注册到注册中心的逻辑,这通常涉及到服务的元数据(如接口名、...

Global site tag (gtag.js) - Google Analytics