1、基本原理
RPC底层原理:
服务端:暴露一个服务接口,整个接口中方法逻辑实现
暴露服务接口:
Map<String,Object>
key:暴露服务接口的名称
value:这个接口对应的实现类的实例
通过客户端传入的接口名称获取暴露服务列表中的接口实例,通过反射调用对应方法
客户端:调用暴露一个服务接口,不用管整个接口的具体实现逻辑,只管调用获取相应结果就ok
接口能直接调用:不能
1、接口找到接口的实现类---no(接口的实现类不在这个机器上面,而在远程实现的)
2、使用代理来为接口生成对应代理类--- ok
3、通过网络连接找到服务端调用服务端对应接口的具体实现类中的方法
2.1、网络连接
2.2、需要把调用这个方法需要的数据准备并打包发送给服务端
2.3、准备参数【参数类型,值列表】
方法名称、接口名称
2、服务端代码
public class RpcServer {
private Map<String , Object> serviceMap = new ConcurrentHashMap<>(32);
//创建线程池管理线程提高线程复用及限制线程数
private ThreadPoolExecutor executor = new ThreadPoolExecutor(8, 20, 200, TimeUnit.MILLISECONDS, new ArrayBlockingQueue(10));
public void publishService(Class<?> interfaceClass, Object instance){
this.serviceMap.put(interfaceClass.getName(), instance);
}
/**
* 启动服务的方法
* @param port
*/
public void start(int port){
try{
//监听客户端发送数据
ServerSocket serverSocket = new ServerSocket();
serverSocket.bind(new InetSocketAddre