RPC底层实现

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值