Introduction
Java RMI, Remote Method Invocation (Remote Method Invocation), a Java API used to implement remote procedure call (RPCRemote procedure call), can directly transmit serialized Java objects. Its implementation relies on the Java Virtual Machine, so it only supports calls from one JVM to another.
1. The server generates a registry and binds a port.
2. The server registers the service interface that needs to be published into the registry.
3. Start the service and wait for consumers
4. The consumer obtains the registry based on the IP and port of the server
5. The consumer obtains the service interface that wants to provide services based on the name from the registry
6. The consumer calls the method in the interface to complete the method Call
Environment setup
Create a project module
Create pojo class:
package cn.hu.rmi.pojo; import java.io.Serializable; /** * @Author: hu.chen * @Description: 因为需要序列化和反序列化,所以需要实现Serializable接口 * @DateTime: 2021/12/26 5:05 PM **/ public class User implements Serializable { private Integer id; private String name; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "User{" + "id=" + id + ", name='" + name + '\'' + '}'; } }
Create user interface:
package cn.hu.rmi.service; import cn.hu.rmi.pojo.User; import java.rmi.Remote; import java.rmi.RemoteException; /** * @Author: hu.chen * @Description: 需要提供服务的接口需要继承 Remote 并且所有的方法都需要抛出 RemoteException 异常 * @DateTime: 2021/12/26 5:06 PM **/ public interface UserService extends Remote { /** * 所有的方法都需要抛出 RemoteException 异常 * @param id * @return * @throws RemoteException */ User getUserById(Integer id) throws RemoteException; }
Service provider:
创建userservice的实现类 package cn.hu.rmi.service.impl; import cn.hu.rmi.pojo.User; import cn.hu.rmi.service.UserService; import java.rmi.RemoteException; import java.rmi.server.UnicastRemoteObject; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; /** * @Author: hu.chen * @Description: 所有的实现类都需要继承 UnicastRemoteObject 这个类 * @DateTime: 2021/12/26 5:07 PM **/ public class UserServiceImpl extends UnicastRemoteObject implements UserService { private static Map<Integer,User> userMap=new ConcurrentHashMap<>(8); static { User user1=new User(); user1.setId(1); user1.setName("张三"); User user2=new User(); user2.setId(2); user2.setName("李四"); userMap.put(user1.getId(),user1); userMap.put(user2.getId(),user2); } public UserServiceImpl() throws RemoteException { super(); } @Override public User getUserById(Integer id) throws RemoteException { return userMap.get(id); } }
Start and add the implementation class to the registry:
package cn.hu.rmi.server; import cn.hu.rmi.service.UserService; import cn.hu.rmi.service.impl.UserServiceImpl; import java.rmi.RemoteException; import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; /** * @Author: hu.chen * @Description: 服务端(服务提供者) * @DateTime: 2021/12/26 5:11 PM **/ public class RmiServer { public static void main(String[] args) throws RemoteException { // 1: 创建注册表对象,之后服务提供者暴露的服务都需要注册到这个注册表中 Registry registry = LocateRegistry.createRegistry(8089); UserService userService=new UserServiceImpl(); // 将需要提供的service服务注册到注册表中 registry.rebind("userService",userService); System.err.println("服务提供者启动成功"); } }
Service consumer:
package cn.hu.rmi.client; import cn.hu.rmi.pojo.User; import cn.hu.rmi.service.UserService; import java.rmi.NotBoundException; import java.rmi.RemoteException; import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; /** * @Author: hu.chen * @Description: 客户端(服务消费者) * @DateTime: 2021/12/26 5:18 PM **/ public class RmiClient { public static void main(String[] args) throws RemoteException, NotBoundException { //1: 获取远程的注册表 Registry registry = LocateRegistry.getRegistry("127.0.0.1", 8089); UserService userService= (UserService) registry.lookup("userService"); User userById = userService.getUserById(1); System.err.println(userById); } }
Start the service provider, and then start the service consumer:
The above is the detailed content of How to call java remotely based on RMI. For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于设计模式的相关问题,主要将装饰器模式的相关内容,指在不改变现有对象结构的情况下,动态地给该对象增加一些职责的模式,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SublimeText3 Chinese version
Chinese version, very easy to use

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Dreamweaver Mac version
Visual web development tools
