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都是轻量级的,可以使用在内存限制的环境下
分享到:
相关推荐
首先,我们要明确Spring远程调用(Remoting)的基本概念。远程调用是指应用程序的不同组件或服务之间,通过网络进行通信的一种方式。Spring支持多种远程调用协议,如RMI(Remote Method Invocation)、Hessian、 ...
首先,我们需要理解什么是Spring远程调用。Spring Remote提供了一种机制,使得应用程序能够跨越网络边界调用其他服务的方法,仿佛它们是在同一进程中执行一样。HTTP远程调用是Spring Remote的一种实现方式,通过HTTP...
因为上传大小的限制,分为两部分上传,这是第二部分,... 第16章 Spring远程服务和Web服务 第17章 Spring对EJB和JMS的支持 第18章 Spring对JMX、电子邮件和调度的支持 第19章 Spring中的脚本编程
在Java EE平台上,Spring框架提供了一种强大的方式来实现远程服务调用,特别是通过其HttpInvokerServiceExporter组件来实现基于HTTP的WebService功能。这个技术允许客户端和服务端通过HTTP协议进行通信,实现远程...
5. **客户端调用**:最后,客户端可以像调用本地对象一样调用远程服务。我们只需要获取HttpInvokerProxyFactoryBean创建的代理对象,然后直接调用接口方法即可。 ```java @Autowired private UserService ...
因为上传大小的限制,分为两部分上传,这是第一部分,... 第16章 Spring远程服务和Web服务 第17章 Spring对EJB和JMS的支持 第18章 Spring对JMX、电子邮件和调度的支持 第19章 Spring中的脚本编程
- **Spring远程服务**:Spring框架支持多种远程服务调用机制,如RMI、HTTP invoker等,简化了远程服务的开发和部署。 5. **Web层支持** - **Spring MVC**:Spring框架提供了一种模型-视图-控制器(Model-View-...
Spring专家力作 理论与实践完美结合 问题描述→解决方案... 第16章 Spring远程服务和Web服务 第17章 Spring对EJB和JMS的支持 第18章 Spring对JMX、电子邮件和调度的支持 第19章 Spring中的脚本编程
标题中的"Spring 远程调用"指的是Spring的远程服务访问(Remote Service Access,RSA)。RSA允许服务提供者创建远程服务,而服务消费者可以跨网络调用这些服务。在Web服务上下文中,Spring提供了WebServiceTemplate...
Spring Cloud Feign 是一个基于 Java 的声明式 RESTful 客户端,提供了一种简单、可靠的方式来调用远程服务。在本文中,我们将介绍如何使用 Spring Cloud Feign 实现远程调用服务传输文件的方法。 Feign 介绍 ...
Spring远程访问通过使用普通POJOs,能更容易的开发远程访问服务。目前,Spring远程访问的主要技术如下: 1. 远程调用RMI(Remote Method Invocation): 通过使用 RmiProxyFactoryBean 和 RmiServiceExporter,并且,...
本篇文章将深入探讨如何将Spring与Hessian整合,以便在分布式系统中轻松实现远程服务调用。 首先,让我们理解Spring整合Hessian的基本原理。Spring通过其强大的IoC(Inversion of Control)容器管理服务和客户端,...
上文我们利用Spring rmi实现了Spring的远程访问(Spring 实现远程访问详解——rmi),本文主要讲解利用HttpInvoke实现远程访问。 Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和...
在Spring中,RMI的实现被集成到IoC(Inversion of Control)容器中,这样可以方便地管理和配置远程服务。 服务端的实现通常包括以下步骤: 1. **定义远程接口**:这是服务端提供给客户端调用的接口,需要使用`@...
"Spring Boot 使用 FTP 方式上传文件到远程服务器" 在本文中,我们将详细介绍如何使用 Spring Boot 框架来实现 FTP 方式上传文件到远程服务器。FTP(File Transfer Protocol)是一种常用的文件传输协议,广泛应用于...
使用eclipse maven工程搭建hessian远程服务demo 分服务端的整合和客户端 建议阅读相关博客http://blog.csdn.net/heisemuyangquan/article/details/79460528
标题 "spring远程调用和xfire aegis 源代码上传" 涉及到的是在Java开发中使用Spring框架进行远程过程调用(RPC)以及整合XFire和Aegis库来实现服务间的通信。这一主题是分布式系统设计中的一个重要组成部分,特别是...
本项目为spring-boot+webSocket实现的向日葵远程控制项目 向日葵是一款很好用的远程操作软件。 一直很好奇这种软件的基本原理是如何的? 今天带大家通过一个简单的项目来探究一下,并实现一个简单的远程操控软件 ...
首先,理解Spring远程服务调用的核心概念。Spring Remoting是Spring框架的一部分,它提供了一种透明的方式来调用远程服务,仿佛它们是本地对象一样。这包括了RMI、Hessian、 Burlap以及HTTP-based协议如Web Services...