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

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

    博客分类:
  • Java
阅读更多

<!--  Hessian服务的接口-->

 <property name="serviceInterface" value="com.demo.api.server.DemoService" />

</bean>

在该配置下,Hessian服务的url

http://IP:port/**/remote/HessianService,其中**是该应用的urlSpring使用DispatcherServlet拦截到匹配/remoting/*的请求,然后将该请求转发到对应的bean,该beandispatcher-servlet.xml文件中以HessianServiceExporter定义。

 

二.客户端

同样我们创建工程和代码

Web project&code

public interface DemoService {

    List getUsers();

}

下面注意了:

创建可序列化对象,就是Server端的那个syncobject,而且要implements Serializable。这个也是我们要远程对象调用的domain类。

public class SyncObject implements Serializable {

    /**

     * Comment for <code>serialVersionUID</code>

     */

    private static final long serialVersionUID = 1L;

    private String username="";

    private String password="";

    public String getUsername() {

       return username;

    }

    public void setUsername(String username) {

       this.username = username;

    }

    public String getPassword() {

       return password;

    }

    public void setPassword(String password) {

       this.password = password;

    }

}

配置文件config.xml

<bean id="hessianService" class="org.springframework.remoting.caucho.HessianProxyFactoryBean">

<!--服务器端发布的地址URL-->

        <property name="serviceUrl" value="http://ip:port/**/remote/HessianService" />

<!--本地接口à

        <property name="serviceInterface" value="com.demo.api.client.DemoService"/>

</bean>

最后我们写个测试方法:

public static void main(String[] args) {

        final ApplicationContext context = new ClassPathXmlApplicationContext("config.xml");

        DemoService service = (DemoService)context.getBean("hessianService");

        try {

        List<SyncObject> userlist= service.getUsers();

         for (SyncObject user : userlist) {

              System.out.println(user.getUsername());

         }   

        }

        catch(RemoteException e) {

           e.printStackTrace();

        }

}

Run一把试试,(确保服务器端runing状态哦)

下面是成功后的信息,结果是从服务器端取到了2个用户的username

2008-12-31 10:31:15 org.springframework.core.CollectionFactory <clinit>

信息: JDK 1.4+ collections available

2008-12-31 10:31:16 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions

信息: Loading XML bean definitions from class path resource [config.xml]

2008-12-31 10:31:16 org.springframework.context.support.AbstractRefreshableApplicationContext refreshBeanFactory

信息: Bean factory for application context [org.springframework.context.support.ClassPathXmlApplicationContext;hashCode=11988197]: org.springframework.beans.factory.support.DefaultListableBeanFactory defining beans [hessianService]; root of BeanFactory hierarchy

2008-12-31 10:31:16 org.springframework.context.support.AbstractApplicationContext refresh

信息: 1 beans defined in application context [org.springframework.context.support.ClassPathXmlApplicationContext;hashCode=11988197]

2008-12-31 10:31:16 org.springframework.context.support.AbstractApplicationContext initMessageSource

信息: Unable to locate MessageSource with name 'messageSource': using default [org.springframework.context.support.DelegatingMessageSource@b8f82d]

2008-12-31 10:31:16 org.springframework.context.support.AbstractApplicationContext initApplicationEventMulticaster

信息: Unable to locate ApplicationEventMulticaster with name 'applicationEventMulticaster': using default [org.springframework.context.event.SimpleApplicationEventMulticaster@b1b4c3]

2008-12-31 10:31:16 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons

信息: Pre-instantiating singletons in factory [org.springframework.beans.factory.support.DefaultListableBeanFactory defining beans [hessianService]; root of BeanFactory hierarchy]

2008-12-31 10:31:16 org.springframework.aop.framework.DefaultAopProxyFactory <clinit>

信息: CGLIB2 not available: proxyTargetClass feature disabled

username1 from server

username2 from server

 

分享到:
评论

相关推荐

    Hessian学习简单demo

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

    hessian+spring小案例

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

    Hessian的demo

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

    CXF+RMI+HESSIAN

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

    springboot-httpinvoker-demo.zip

    2. 服务器端接收请求:服务器接收到请求后,通过`HttpInvokerServiceExporter`解析请求,找到对应的服务实现,并调用相应的方法。 3. 数据传输:请求和响应的数据都通过HTTP协议进行传输,Spring会自动处理对象的...

    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