分布式(基础)-RMI简单的应用

简介: 分布式(基础)-RMI简单的应用

RMI的简单的应用

远程通信:不同的jvm之间进行通信,不同的虚拟机就是跨服务的通信。

RMI:jdk自带的远程通信的一个接口,java本身提供的远程通信框架,称不上rpc。RMI是依赖于jvm,不依赖于apache。

常见的rpc框架有:Dubbo,Thrift,WebService(WSDL)=>http+XML:而现在都替换成http+json的方式来进行通信了。

写一个RMI的实例:底层就是用的Socket来进行通信的,但是它不支持跨语言,基于JRMP协议的,rmi的性能很高的。

RMI是WebService的根基。

1、新建两个java工程,一个代表客户端,一个代表服务端:

2、在server端提供一个UserDao的接口,代码如下:

  1. package dao;

  2. import java.rmi.RemoteException;

  3. /**
  4. * 接口里的方法必须抛RemoteException的异常
  5. */
  6. public interface UserDao extends java.rmi.Remote {
  7.     String addUser(String name) throws RemoteException;
  8. }

2.1、UserDao的实现类如下:

  1. package dao;

  2. import java.rmi.RemoteException;
  3. import java.rmi.server.UnicastRemoteObject;

  4. //UnicastRemoteObject这个类用于RemoteImpl这个类发布出去做一个序列化的处理,继承这个类的话,会在主类的时候会开启一个线程
  5. public class UserDaoImpl extends UnicastRemoteObject implements UserDao {
  6.    public UserDaoImpl() throws RemoteException {
  7.    }

  8.    @Override
  9.    public String addUser(String name) throws RemoteException {
  10.        return "添加的用户名称为"+name;
  11.    }
  12. }

2.2、server端的主类的代码如下:绑定的是接口,然后会生成一个代理,通过这个代理,然后和客户端的代理进行通信的去实现网络通信的操作。

  1. package rmi;

  2. import dao.UserDao;
  3. import dao.UserDaoImpl;

  4. import java.net.MalformedURLException;
  5. import java.rmi.AlreadyBoundException;
  6. import java.rmi.Naming;
  7. import java.rmi.RemoteException;
  8. import java.rmi.registry.LocateRegistry;

  9. public class RmiServer {
  10.    public static void main(String[] args) throws InterruptedException, RemoteException {
  11.        //创建接口引用的实例
  12.        UserDao remote=new UserDaoImpl();
  13.        try {
  14.            //注册要被客户端监听的端口
  15.            LocateRegistry.createRegistry(8888);
  16.            try {
  17.                //rmi:是固定的写法
  18.                Naming.bind("rmi://localhost:8888/user",remote);
  19.                System.out.println("server starting...........");
  20.            } catch (AlreadyBoundException e) {
  21.                e.printStackTrace();
  22.            } catch (MalformedURLException e) {
  23.                e.printStackTrace();
  24.            }
  25.        } catch (RemoteException e) {
  26.            e.printStackTrace();
  27.        }
  28.    }
  29. }

启动server端:

3、客户端的接口的代码和server端的接口是一样,因为需要把接口给暴漏出去,代码如下:

  1. package dao;

  2. import java.rmi.RemoteException;

  3. /**
  4. * 接口里的方法必须抛RemoteException的异常
  5. */
  6. public interface UserDao extends java.rmi.Remote {
  7.     String addUser(String name) throws RemoteException;
  8. }

3.1、客户端的主类的代码如下Naming是命,lookup寻找地址是否存在。

  1. package rmi.client;
  2. import dao.UserDao;
  3. import java.net.MalformedURLException;
  4. import java.rmi.Naming;
  5. import java.rmi.NotBoundException;
  6. import java.rmi.RemoteException;
  7. public class RmiClient {
  8.    public static void main(String[] args) {
  9.        try {
  10.            UserDao userDao = (UserDao)Naming.lookup("rmi://localhost:8888/user");
  11.            System.out.println(userDao.addUser("weizhaoyang"));
  12.        } catch (NotBoundException e) {
  13.            e.printStackTrace();
  14.        } catch (MalformedURLException e) {
  15.            e.printStackTrace();
  16.        } catch (RemoteException e) {
  17.            e.printStackTrace();
  18.        }
  19.    }
  20. }

启动客户端:

注意:如下,服务端的接口和客户端的接口的路径必须一样,否则也会报错。

因为需要 代理是实现类应该是一样的。

未完待续!!如果哪里写的有问题,请指出。xxxxxxxxxxxxxxxxxxx谢谢。

相关文章
|
2月前
|
缓存 NoSQL PHP
Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出
本文深入探讨了Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出。文章还介绍了Redis在页面缓存、数据缓存和会话缓存等应用场景中的使用,并强调了缓存数据一致性、过期时间设置、容量控制和安全问题的重要性。
46 5
|
3月前
|
人工智能 文字识别 Java
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
尼恩,一位拥有20年架构经验的老架构师,通过其深厚的架构功力,成功指导了一位9年经验的网易工程师转型为大模型架构师,薪资逆涨50%,年薪近80W。尼恩的指导不仅帮助这位工程师在一年内成为大模型架构师,还让他管理起了10人团队,产品成功应用于多家大中型企业。尼恩因此决定编写《LLM大模型学习圣经》系列,帮助更多人掌握大模型架构,实现职业跃迁。该系列包括《从0到1吃透Transformer技术底座》、《从0到1精通RAG架构》等,旨在系统化、体系化地讲解大模型技术,助力读者实现“offer直提”。此外,尼恩还分享了多个技术圣经,如《NIO圣经》、《Docker圣经》等,帮助读者深入理解核心技术。
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
|
4月前
|
存储 NoSQL Java
分布式session-SpringSession的应用
Spring Session 提供了一种创建和管理 Servlet HttpSession 的方案,默认使用外置 Redis 存储 Session 数据,解决了 Session 共享问题。其特性包括:API 及实现用于管理用户会话、以应用容器中性方式替换 HttpSession、简化集群会话支持、管理单个浏览器实例中的多个用户会话以及通过 headers 提供会话 ID 以使用 RESTful API。Spring Session 通过 SessionRepositoryFilter 实现,拦截请求并转换 request 和 response 对象,从而实现 Session 的创建与管理。
分布式session-SpringSession的应用
|
4月前
|
存储 NoSQL Java
分布式session-SpringSession的应用
Spring Session 提供了一种创建和管理 Servlet HttpSession 的方案,默认使用外置 Redis 存储 Session 数据,解决 Session 共享问题。其主要特性包括:提供 API 和实现来管理用户会话,以中立方式替换应用程序容器中的 HttpSession,简化集群会话支持,并在单个浏览器实例中管理多个用户会话。此外,Spring Session 允许通过 headers 提供会话 ID 以使用 RESTful API。结合 Spring Boot 使用时,可通过配置 Redis 依赖和支持缓存的依赖实现 Session 共享。
分布式session-SpringSession的应用
|
3月前
|
缓存 网络协议 API
分布式系统应用之服务发现!
分布式系统应用之服务发现!
|
4月前
|
存储 运维 应用服务中间件
阿里云分布式存储应用示例
通过阿里云EDAS,您可以轻松部署与管理微服务应用。创建应用时,使用`CreateApplication`接口基于模板生成新应用,并获得包含应用ID在内的成功响应。随后,利用`DeployApplication`接口将应用部署至云端,返回"Success"确认部署成功。当业务调整需下线应用时,调用`ReleaseApplication`接口释放资源。阿里云EDAS简化了应用全生命周期管理,提升了运维效率与可靠性。[相关链接]提供了详细的操作与返回参数说明。
|
5月前
|
机器学习/深度学习 分布式计算 PyTorch
大规模数据集管理:DataLoader在分布式环境中的应用
【8月更文第29天】随着大数据时代的到来,如何高效地处理和利用大规模数据集成为了许多领域面临的关键挑战之一。本文将探讨如何在分布式环境中使用`DataLoader`来优化大规模数据集的管理与加载过程,并通过具体的代码示例展示其实现方法。
287 1
|
4月前
|
网络协议 安全 Java
分布式(基础)-RMI的原理
分布式(基础)-RMI的原理
|
5月前
|
运维 安全 Cloud Native
核心系统转型问题之保障云原生分布式转型中的基础设施和应用层面如何解决
核心系统转型问题之保障云原生分布式转型中的基础设施和应用层面如何解决
|
5月前
|
Kubernetes 安全 云计算
分布式应用的终极革命:Distributionless,告别分布式烦恼!
【8月更文挑战第8天】探讨分布式应用的进化形态——Distributionless,一种使开发者聚焦业务逻辑而非系统细节的理念。借助容器化、云计算与自动化工具的进步,分布式应用的开发与管理变得简易。透过示例展现了使用Bazel构建及Kubernetes部署的流程,预示着Distributionless模式下的应用将更加高效、可靠与安全,引领未来分布式应用的发展趋势。
70 7