远程服务调用RMI框架 演示,和底层原理解析
远程服务调用RMI框架: 是纯java写的, 只支持java服务之间的远程调用,很简单,
// 接口要继承 Remote接口
public interface IHelloService extends Remote {
public String sayHello(String msg)throws RemoteException;
}
//实现类 要继承 UnicastRemoteObject 类, 并重写 构造方法
public class HelloServiceImpl extends UnicastRemoteObject implements IHelloService {
protected HelloServiceImpl() throws RemoteException {
super();
}
@Override
public String sayHello(String msg) throws RemoteException{
return "hello "+msg;
}
}
## 发布服务
public class RMI_Server {
public static void main(String[] args) throws Exception {
//这是将 本服务发布出去
IHelloService helloService = new HelloServiceImpl();
//这是将 locateRegistry 相当于注册中心, 发布出去
LocateRegistry.createRegistry(1099);
//这是将 rul 和 服务,存到 HashTable中, 并发布出去
Naming.bind("rmi://127.0.0.1/hello",helloService);
System.out.println("服务发布成功");
}
}
## 服务调用client
public class RMI_Client {
public static void main(String[] args) throws RemoteException, NotBoundException, MalformedURLException {
IHelloService helloService = (IHelloService) Naming.lookup("rmi://127.0.0.1/hello");
System.out.println(helloService.sayHello("啦啦啦啦啊"));
}
}
运行结果:
源码解读: 这里参考别人博客,自己不重复造轮子:
https://blog.csdn.net/qq_20597727/article/details/80861906
自己理解:
HelloServiceImpl ---> 构造-->exportObject(obj, new UnicastServerRef(port));--->1:这里先对当前对象代理生成代理对象, 将代理对象包装成Target对象,发布出去--->TCPEndPoint发布服务(可以将这里看做传输层) ---> this.listen(); 监听( 这里面可看到 工厂模式 new 了一个 serverSocket, 并创建一个线程 (这个线程循环 socket阻塞, 当监听到client过来的时候, 线程池调用线程,发送,当前服务对象, 最后关闭 serverSocket) )
LocateRegistry.createRegistry(1099); ------>this.setup(new UnicastServerRef(var2, RegistryImpl::registryFilter));----->var1.exportObject(this, (Object)null, true);----> 接下来和 发布服务是一样的... 这个操作是将LocateRegistry 发布出去, LocateRegistry相当于注册中心,是单独的一个进程,在 java/bin下
Naming.bind("rmi://127.0.0.1/hello",helloService); -----> 这个是将url 和对应服务 绑定起来,---> 先获取这侧表, 然后注册表将 url 和 对应服务绑定 内部其实是一个Hashtable , url---key, 服务--->value , 获取一个新连接, 将 url和服务 发送出去
Client 端, IHelloService helloService = (IHelloService) Naming.lookup("rmi://127.0.0.1/hello"); --->先获取到注册表, 然后监听 对应的 rul, 先从HashTable中根据url 获取服务,有就直接返回
远程服务调用RMI框架 演示,和底层原理解析的更多相关文章
- 分布式远程服务调用(RPC)框架
分布式远程服务调用(RPC)框架 finagle:一个支持容错,协议无关的RPC系统 热门度(没变化) 10.0 活跃度(没变化) 10.0 Watchers:581 Star:6174 Fork: ...
- 远程服务调用RPC框架介绍,微服务架构介绍和RPC框架对比,dubbo、SpringClound对比
远程服务调用RPC框架介绍,微服务架构介绍和RPC框架对比,dubbo.SpringClound对比 远程服务调用RPC框架介绍,RPC简单的来说就是像调用本地服务一样调用远程服务. 分布式RPC需要 ...
- dubbo专题」dubbo其实很简单,就是一个远程服务调用的框架(1)
一.dubbo是什么? 1)本质:一个Jar包,一个分布式框架,,一个远程服务调用的分布式框架. 既然是新手教学,肯定很多同学不明白什么是分布式和远程服务调用,为什么要分布式,为什么要远程调用.我简单 ...
- git的核心命令使用和底层原理解析
文章目录: GIT体系概述 GIT 核心命令使用 GIT 底层原理 一.GIT体系概述 GIT 与 svn 主要区别: 存储方式不一样 使用方式不一样 管理模式不一样 1.存储方式区别 GIT把内容按 ...
- Spring Cloud底层原理解析
概述 毫无疑问,Spring Cloud是目前微服务架构领域的翘楚,无数的书籍博客都在讲解这个技术.不过大多数讲解还停留在对Spring Cloud功能使用的层面,其底层的很多原理,很多人可能并不知晓 ...
- Spring框架实现——远程方法调用RMI代码演示
1.spring_RMI02_server服务端02 <?xml version="1.0" encoding="UTF-8"?> <bean ...
- JAVA框架 Spring AOP底层原理
一:AOP(Aspect Oriented Programming)面向切面编程. 底层实现原理是java的动态代理:1.jdk的动态代理.2.spring的cglib代理. jdk的动态代理需要被代 ...
- 普通方法实现——远程方法调用RMI代码演示
1.spring_RMI01_server服务端 package com.wisezone.service; import java.rmi.Remote; import java.rmi.Remot ...
- 基于框架的RPC通信技术原理解析
RPC的由来 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时, ...
随机推荐
- POJ 2135 简单费用流
题意: 题意是一个人他要从牧场1走到牧场n然后在走回来,每条路径只走一次,问全程的最短路径是多少. 思路: 这个题目挺简单的吧,首先要保证每条边只能走一次,然后还要要求费用最 ...
- Windows PE导出表编程2(重组导出表函数地址)
本次要做的尝试是通过修改导出表的函数地址,实现程序功能的更改,实现这个最大的限制就是堆栈平衡问题. 先写一个DLL和EXE为了测试. DLL代码如下: 这样的话有两个导出函数(我们假设是一个密码验证之 ...
- Windows Pe 第三章 PE头文件(下)
3.5 数据结构字段详解 3.5.1 PE头IMAGE_NT_HEADER的字段 1.IMAGE_NT_HEADER.Signature +0000h,双字.PE文件标识,被定义为00004550 ...
- 【python】Leetcode每日一题-二叉搜索树节点最小距离
[python]Leetcode每日一题-二叉搜索树节点最小距离 [题目描述] 给你一个二叉搜索树的根节点 root ,返回 树中任意两不同节点值之间的最小差值 . 示例1: 输入:root = [4 ...
- Day002 Java开发环境搭建
Java开发环境搭建 JDK.JRE.JVM JDK: Java Development Kit(包涵JRE) JRE: Java Runtime Environment(包涵JVM) JVM: Ja ...
- 用PS给视频磨皮美颜
无意间找到的,但是一个10分钟的视频渲染了我一天的时间,但是效果是不错的 参考视频链接 https://www.bilibili.com/video/BV1b7411m74e 视频中涉及的添加插件链接 ...
- .Net·快速查找哪一个类库引用了哪一个Package
阅文时长 | 0.18分钟 字数统计 | 348.8字符 主要内容 | 1.引言&背景 2.查找法示例 3.声明与参考资料 『.Net·快速查找哪一个类库引用了哪一个Package』 编写人 ...
- [DB] Zookeeper
介绍 相当于"数据库",类似linux.hdfs的属性文件结构 分布式协调框架,实现HA(High Availability) 分布式锁管理框架 保证数据在zookeeper集群之 ...
- 获取显卡硬件信息lspci -vnn | grep VGA -A 12
lspci -vnn | grep VGA -A 12 lshw -C display lshw -c video | grep configuration glxinfo | grep OpenGL ...
- stm32之ADC应用实例(单通道、多通道、基于DMA)-转载精华帖,最后一部分的代码是精华
硬件:STM32F103VCT6 开发工具:Keil uVision4 下载调试工具:ARM仿真器网上资料很多,这里做一个详细的整合.(也不是很详细,但很通俗).所用的芯片内嵌3个12位的 ...