`
gyht0808
  • 浏览: 114966 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Spring远程服务

阅读更多
RMI
服务端的编写
定义一个接口
IRmiService.java
package com.myspring.rmi;

/**
 * @author kaili.zhukl
 * @2009-10-14
 */
public interface IRmiService {
	public String hello(String name);
}


接口实现RmiServiceImpl.java
package com.myspring.rmi;

/**
 * @author kaili.zhukl
 * @2009-10-14
 */
public class RmiServiceImpl implements IRmiService {

	/* (non-Javadoc)
	 * @see com.myspring.rmi.IRmiService#hello(java.lang.String)
	 */
	public String hello(String name) {
		// TODO Auto-generated method stub
		return "hello" + name;
	}

}

如果创建rmi服务没有使用spring,就需要涉及以下步骤:

    [1]编写服务实现类,类中的方法能够抛出java.rmi.RemoteExecption
    [2]创建服务接口,以便扩展java.rmi.Remote
    [3]运行RMI编译器(rmic),创建客户端stub类和服务器端skeleton类
    [4]启动一个RMI注册,以便驻留这些服务.
    [5]在RMI注册表中注册服务
为了避免如此繁重的步骤和可能出现的异常,我们使用spring的RmiServiceExporter,把Spring管理的Bean输出成一个RMI服务
配置文件spring-rmi.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xmlns:p="http://www.springframework.org/schema/p"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

	<bean id="rmiService" class="com.myspring.rmi.RmiServiceImpl"/>
	
	<bean id="serviceExporter" class="org.springframework.remoting.rmi.RmiServiceExporter">
		<property name="service">
			<ref bean="rmiService"/>
		</property>
		<!-- 定义服务名 -->
		<property name="serviceName">
			<value>rmi</value>
		</property>
		<!-- 定义服务实现接口-->
		<property name="serviceInterface">
			<value>com.myspring.rmi.IRmiService</value>
		</property>
		<!-- 定义服务端口 -->
		<property name="registryPort">
            <value>8888</value>
        </property>
	</bean>
	
	<bean id="serviceClient"  
        class="org.springframework.remoting.rmi.RmiProxyFactoryBean">  
           
        <property name="serviceInterface">  
            <value>com.myspring.rmi.IRmiService</value>  
        </property>  
        <!-- serviceUrl以rmi开头,定义服务器地址与端口和服务名 -->  
        <property name="serviceUrl">  
            <value>rmi://localhost:8888/rmi</value>  
        </property>  
    </bean>  
	
</beans>

客户端类 RMIClient.java
package com.myspring.rmi;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class RMIClient {
	 public static void main(String[] args) {   
	        ApplicationContext ac = new ClassPathXmlApplicationContext("com/myspring/rmi/spring-rmi.xml"); 
	        IRmiService rmiService = (IRmiService) ac.getBean("serviceClient");
	        System.out.println(rmiService.hello("dd"));
	    }  
}

Hessian和Burlap
Hessian和RMI那样,使用二进制消息来建立客户端和服务端之间的交流.但与其他二进制远程技术(RMI)不容的是,它的二进制消息可以移植到其他非java的语言中,包括PHP,Python,C++和C#.
Burlap是一种基于XML的远程技术,可以移植到任何可以解析XML的语言中,可读性强
Hessian和Burlap都是轻量级的,可以使用在内存限制的环境下
1
0
分享到:
评论
1 楼 yin_bp 2011-05-19  
bbossgroups 3.2添加了直接发布rmi服务的方法,详情可查看iteye上bbossgroups专栏文章《bbossgroups 3.2 中rmi组件服务发布和rmi客服端获取方法》:
http://www.iteye.com/wiki/bbossgroups/3089-bbossgroups-aop-rmi

相关推荐

    spring远程调用简单实例

    首先,我们要明确Spring远程调用(Remoting)的基本概念。远程调用是指应用程序的不同组件或服务之间,通过网络进行通信的一种方式。Spring支持多种远程调用协议,如RMI(Remote Method Invocation)、Hessian、 ...

    Spring远程调用使用http方式

    首先,我们需要理解什么是Spring远程调用。Spring Remote提供了一种机制,使得应用程序能够跨越网络边界调用其他服务的方法,仿佛它们是在同一进程中执行一样。HTTP远程调用是Spring Remote的一种实现方式,通过HTTP...

    Spring攻略PDF版

    因为上传大小的限制,分为两部分上传,这是第二部分,... 第16章 Spring远程服务和Web服务   第17章 Spring对EJB和JMS的支持   第18章 Spring对JMX、电子邮件和调度的支持   第19章 Spring中的脚本编程 

    spring远程调用

    5. **客户端调用**:最后,客户端可以像调用本地对象一样调用远程服务。我们只需要获取HttpInvokerProxyFactoryBean创建的代理对象,然后直接调用接口方法即可。 ```java @Autowired private UserService ...

    使用spring远程调用服务端接口实现WebService功能

    在Java EE平台上,Spring框架提供了一种强大的方式来实现远程服务调用,特别是通过其HttpInvokerServiceExporter组件来实现基于HTTP的WebService功能。这个技术允许客户端和服务端通过HTTP协议进行通信,实现远程...

    Spring攻略中文版PDF

    因为上传大小的限制,分为两部分上传,这是第一部分,... 第16章 Spring远程服务和Web服务   第17章 Spring对EJB和JMS的支持   第18章 Spring对JMX、电子邮件和调度的支持   第19章 Spring中的脚本编程 

    Spring in Action 2nd Edition

    - **Spring远程服务**:Spring框架支持多种远程服务调用机制,如RMI、HTTP invoker等,简化了远程服务的开发和部署。 5. **Web层支持** - **Spring MVC**:Spring框架提供了一种模型-视图-控制器(Model-View-...

    Spring攻略英文版(附带源码)

    Spring专家力作 理论与实践完美结合 问题描述→解决方案... 第16章 Spring远程服务和Web服务   第17章 Spring对EJB和JMS的支持   第18章 Spring对JMX、电子邮件和调度的支持   第19章 Spring中的脚本编程 

    Spring 远程调用 -- C# 访问java WEB 服务

    标题中的"Spring 远程调用"指的是Spring的远程服务访问(Remote Service Access,RSA)。RSA允许服务提供者创建远程服务,而服务消费者可以跨网络调用这些服务。在Web服务上下文中,Spring提供了WebServiceTemplate...

    spring cloud feign实现远程调用服务传输文件的方法

    Spring Cloud Feign 是一个基于 Java 的声明式 RESTful 客户端,提供了一种简单、可靠的方式来调用远程服务。在本文中,我们将介绍如何使用 Spring Cloud Feign 实现远程调用服务传输文件的方法。 Feign 介绍 ...

    Spring 实现远程访问详解——rmi

    Spring远程访问通过使用普通POJOs,能更容易的开发远程访问服务。目前,Spring远程访问的主要技术如下: 1. 远程调用RMI(Remote Method Invocation): 通过使用 RmiProxyFactoryBean 和 RmiServiceExporter,并且,...

    Spring整合Hessian访问远程服务

    本篇文章将深入探讨如何将Spring与Hessian整合,以便在分布式系统中轻松实现远程服务调用。 首先,让我们理解Spring整合Hessian的基本原理。Spring通过其强大的IoC(Inversion of Control)容器管理服务和客户端,...

    Spring 实现远程访问详解——httpinvoker

    上文我们利用Spring rmi实现了Spring的远程访问(Spring 实现远程访问详解——rmi),本文主要讲解利用HttpInvoke实现远程访问。 Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和...

    spring RMI 远程接口调用

    在Spring中,RMI的实现被集成到IoC(Inversion of Control)容器中,这样可以方便地管理和配置远程服务。 服务端的实现通常包括以下步骤: 1. **定义远程接口**:这是服务端提供给客户端调用的接口,需要使用`@...

    springboot以FTP方式上传文件到远程服务器

    "Spring Boot 使用 FTP 方式上传文件到远程服务器" 在本文中,我们将详细介绍如何使用 Spring Boot 框架来实现 FTP 方式上传文件到远程服务器。FTP(File Transfer Protocol)是一种常用的文件传输协议,广泛应用于...

    Spring配置hessian远程服务

    使用eclipse maven工程搭建hessian远程服务demo 分服务端的整合和客户端 建议阅读相关博客http://blog.csdn.net/heisemuyangquan/article/details/79460528

    spring远程调用和xfire aegis 源代码上传

    标题 "spring远程调用和xfire aegis 源代码上传" 涉及到的是在Java开发中使用Spring框架进行远程过程调用(RPC)以及整合XFire和Aegis库来实现服务间的通信。这一主题是分布式系统设计中的一个重要组成部分,特别是...

    spring-boot+webSocket实现向日葵远程控制

    本项目为spring-boot+webSocket实现的向日葵远程控制项目 向日葵是一款很好用的远程操作软件。 一直很好奇这种软件的基本原理是如何的? 今天带大家通过一个简单的项目来探究一下,并实现一个简单的远程操控软件 ...

    spring-remote-service-example:一个示例项目,用于展示如何使用 JSON 反序列化通过 HTTP 在隔离的 Spring 容器之间进行(远程)服务调用

    首先,理解Spring远程服务调用的核心概念。Spring Remoting是Spring框架的一部分,它提供了一种透明的方式来调用远程服务,仿佛它们是本地对象一样。这包括了RMI、Hessian、 Burlap以及HTTP-based协议如Web Services...

Global site tag (gtag.js) - Google Analytics