使用NIO来实现RPC

本文介绍了如何使用NIO实现RPC服务。客户端通过特定格式发送接口名、方法名及参数到服务器,服务器解析并执行对应的方法,再将结果回传给客户端。服务器端创建ServerSocketChannel监听3003端口,注册Selector,接收到请求后反射执行方法,并通过SocketChannel将结果写回。客户端通过RPCClient获取远程代理对象进行调用。
摘要由CSDN通过智能技术生成

数据传输格式:

  客户端调用服务端:

    接口简单名/方法名(参数类型权限名:参数值, . ...)

    比如  SayHello/sayHello(java.lang.String:lalala)

     这里 接口名为SayHello    方法为 sayHello 参数类型为String 内容nana


服务端返回给客户端 

     返回类型:值


服务端代码:


import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.util.HashMap;


/**
 * 它接受的内容是class/方法名(参数类型:参数,参数类型:参数)
 * 
 * @author Administrator
 * 
 */
public class RPCServer {
private static RPCServer instance = new RPCServer();
private HashMap<String, Object> str_obj = new HashMap<>();
private Selector selector;
private ServerSocketChannel ssc;


private RPCServer() {
try {
ssc = ServerSocketChannel.open();
InetSocketAddress address = new InetSocketAddress(3003);
ssc.configureBlocking(false);
ssc.bind(address);
selector = Selector.open();
ssc.register(selector, SelectionKey.OP_ACCEPT);

} catch (Exception e) {
throw new RuntimeException(e);
}
}


public static RPCServer getInstance() {
return instance;
}


public RPCServer addClass(Object obj) {
String name = obj.getClass().getInterfaces()[0].getSimpleName();
str_obj.put(name, obj);
return this;
}


// 开发服务等待连接
public void start() {
System.out.println("-----服务器已经启动了------");
ByteBuffer buff = ByteBuffer.allocate(1024);
try {
while (selector.select() > 0) {
for (SelectionKey sk : selector.selectedKeys()) {
selector.selectedKeys().remove(sk);
if (sk.isAcceptable()) {
// 调用accept方法接受连接,产生服务器端对应的SocketChannel
SocketChannel sc = ssc.accept();
// 设置采用非阻塞模式
sc.configureBlocking(false);
sc.register(selector, SelectionKey.OP_READ);

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值