SpringBoot之RMI的简单使用

1.声明

当前内容用于本人学习RMI,这个基于java的服务发布调用协议,感觉类似webservice,但是RMI只能在java之间产生通信,其他的不支持

2.创建主要的项目springboot-rmi

在这里插入图片描述
在其模块下面添加rmi-api、rmi-client、rmi-server这三个maven模块

pom.xml的配置

<project xmlns="http://maven.apache.org/POM/4.0.0"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.2.5.RELEASE</version>
		<relativePath /> <!-- lookup parent from repository -->
	</parent>
	<groupId>springboot-rmi</groupId>
	<artifactId>springboot-rmi</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>pom</packaging>

	<name>springboot-rmi</name>
	<url>http://maven.apache.org</url>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>

	<modules>
		<module>rmi-server</module>
		<module>rmi-client</module>
		<module>rmi-api</module>
	</modules>
	<dependencies>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<scope>test</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
		</dependency>
	</dependencies>
</project>

3.在rmi-api中创建主要的接口


public interface HelloRMIService {
	void sayHi(String msg);
}

然后将其使用maven build一下,如果出现异常则需要在pom添加

<build>
	<defaultGoal>compile</defaultGoal>
</build>

4.在rmi-server和rmi-client中添加rmi-api的依赖

 <dependency>
  		<artifactId>rmi-api</artifactId>
  		<groupId>rmi-api</groupId>
  		<version>0.0.1-SNAPSHOT</version>
</dependency>

5.在rmi-server中创建实现类和其他的类

创建HelloRMIService 的实现类HelloRMIServiceImpl

@Service
public class HelloRMIServiceImpl implements HelloRMIService {

	@Override
	public void sayHi(String msg) {
		System.out.println("server接收到信息:【" + msg + "】");
	}

}

创建启动入口类

/**
 * @description 用于创建RMIServer
 * @author hy
 * @date 2020-04-16
 */
@SpringBootApplication
public class RMIServerApplication {
	@Autowired
	HelloRMIService service;

	@Bean
	public RmiServiceExporter RmiServiceExporter() {
		RmiServiceExporter exporter = new RmiServiceExporter();
		exporter.setService(service);
		exporter.setServiceName("helloRMI");
		exporter.setServiceInterface(HelloRMIService.class);
		exporter.setRegistryPort(9999);//注意这里必须是注册端口
		try {
			exporter.afterPropertiesSet();
		} catch (RemoteException e) {
			e.printStackTrace();
		}
		return exporter;
	}

	public static void main(String[] args) {
		SpringApplication.run(RMIServerApplication.class, args);
	}
}

配置启动端口:server.port=8002

6.在rmi-client中创建访问服务接口的类

入口类

@SpringBootApplication
public class RMIClientApplication {

	@Bean
	public RmiProxyFactoryBean rmiProxyFactoryBean() {
		RmiProxyFactoryBean bean = new RmiProxyFactoryBean();
		bean.setServiceUrl("rmi://127.0.0.1:9999/helloRMI");
		bean.setServiceInterface(HelloRMIService.class);
		bean.setRefreshStubOnConnectFailure(true);
		return bean;
	}

	public static void main(String[] args) {
		SpringApplication.run(RMIClientApplication.class, args);

	}

}

创建访问controller类

@RestController
public class RMIController {
	@Autowired
	RmiProxyFactoryBean bean;
	
	@RequestMapping("/test")
	public String test(String msg) {
		HelloRMIService service = (HelloRMIService) bean.getObject();
		service.sayHi(msg);
		return "请求成功";
	}
	
}

配置访问端口:server.port=8001

7.测试

先启动rmi-server,再启动rmi-client,最后访问http://localhost:8001/test?msg=123
在这里插入图片描述
在这里插入图片描述
操作成功

8.总结

1.使用springboot集成rmi的时候需要注意的是服务端是发布入口,需要指定注册端口和服务的名称

2.客户端访问的服务端的时候注意和服务端保持一致,否则会报错的

3.通过使用发现和dubbo的以及和webservice感觉一致

以上纯属个人见解,如有问题请联系本人!

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java RMI(Remote Method Invocation)是 Java 中实现远程方法调用的一种机制,它允许一个 Java 程序从另一个 Java 程序中调用对象。下面是一个简单的 Java RMI 的示例: 1. 定义接口 首先需要定义一个接口,用于客户端和服务端之间进行通信。比如: ``` public interface MyInterface extends Remote { public String sayHello() throws RemoteException; } ``` 这里的 MyInterface 继承了 Remote 接口,表示这个接口是一个远程接口。 2. 实现接口 接下来需要在服务端实现这个接口,比如: ``` public class MyInterfaceImpl extends UnicastRemoteObject implements MyInterface { public MyInterfaceImpl() throws RemoteException { super(); } public String sayHello() throws RemoteException { return "Hello, world!"; } } ``` 这里的 MyInterfaceImpl 类实现了 MyInterface 接口,并继承了 UnicastRemoteObject 类。这个类的构造函数需要抛出 RemoteException 异常。 3. 注册服务 在服务端需要将 MyInterfaceImpl 的实例注册到 RMI registry 中,比如: ``` MyInterface myInterface = new MyInterfaceImpl(); Registry registry = LocateRegistry.getRegistry(); registry.bind("MyInterface", myInterface); ``` 这里使用了 LocateRegistry.getRegistry() 方法获取 RMI registry 的引用,然后使用 registry.bind() 方法将 MyInterfaceImpl 的实例注册到 RMI registry 中。 4. 调用服务 在客户端需要获取 MyInterfaceImpl 的实例并调用它的方法,比如: ``` Registry registry = LocateRegistry.getRegistry("localhost"); MyInterface myInterface = (MyInterface) registry.lookup("MyInterface"); String result = myInterface.sayHello(); System.out.println(result); ``` 这里使用了 registry.lookup() 方法获取 MyInterfaceImpl 的实例,然后调用它的 sayHello() 方法并输出结果。 需要注意的是,使用 RMI 调用远程方法时,可能会抛出 RemoteException 异常,需要进行处理。此外,还需要在客户端和服务端都使用相同的接口和实现类,以保证通信的正确性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值