rpc 实现原理

先说一下rpc 的调用过程

客户端:知道接口名和方法名,以及参数类型、调用参数的值 ,但是本地并没有该接口的实现

服务端:这里有接口的实现


调用时,客户端使用JDK动态代理,利用接口创建了一个代理对象

创建代理对象需要两个东西:

1、一个就是接口的全限定名(包名+接口名),

2、还需要一个调用处理接口 InvocationHandler 的实现


说明:每次使用代理对象调用方法时,其实调用的是 InvocationHandler 接口的实现中的invoke 方法

invoke  方法中的实现了远程调用:

        1、根据服务端的IP 和端口号,创建一个socketServer ,

        2、将接口全限定名、方法名、参数类型、参数值、通过socket 传递到服务端

        3、服务端根据接口名获得接口的实现类的实例对象,使用反射调用该方法,得到执行结果

        4、将执行结果写入socket ,传递给客户端

        5、客户端得到结果返回结果

这里是invoke代码

@Override
	public Object invoke(Object proxy, Method method, Object[] args) throws Throwable
	{
		// 把调用服务所需的信息封装到bean中
		InvokerBean invokerBean = new InvokerBean(name, new RPCMethod(method.getName(), method.getParameterTypes()),
				args);

		// 启动socket
		Socket client = new Socket(address, port);

		// 把序列化对象转换成流,使用JDK自带的ObjectOutputStream
		ObjectOutputStream oos = new ObjectOutputStream(client.getOutputStream());
		oos.writeObject(invokerBean);
		oos.flush();

		// 读取服务端返回的结果
		ObjectInputStream ois = new ObjectInputStream(client.getInputStream());
		invokerBean = (InvokerBean) ois.readObject();

		oos.close();
		ois.close();
		client.close();

		return invokerBean.getResult();
	}



整个过程就是rpc 的基本实现原理







  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值