Netty-基于Netty实现RPC-仿Dubbo

1、什么是RPCRPC,英文全称是Remote Procedure Call,翻译过来就是远程过程调用。作为一个计算机通信协议,运行在计算机A的程序调用另一台计算机B上的子程序就像调用本地方法一样方便,而这两个程序是分布在不同的服务器上的RPC远程过程调用图示:其中Client就是RPC服务的消费者,Server就是服务提供者,通过上图可以看到完整的调用关系RPC就是将以上的步骤全部封装起来,用户直接使用,而不用关心使用细节,部署后直接能像使用本地方法一样使用远程程序2、设计一个RPC
摘要由CSDN通过智能技术生成

1、什么是RPC

  • RPC,英文全称是Remote Procedure Call,翻译过来就是远程过程调用。
  • 作为一个计算机通信协议,运行在计算机A的程序调用另一台计算机B上的子程序就像调用本地方法一样方便,而这两个程序是分布在不同的服务器上的
  • RPC远程过程调用图示:
    在这里插入图片描述
    其中Client就是RPC服务的消费者,Server就是服务提供者,通过上图可以看到完整的调用关系
  • RPC就是将以上的步骤全部封装起来,用户直接使用,而不用关心使用细节,部署后直接能像使用本地方法一样使用远程程序

2、设计一个RPC

  • 业界比较主流的RPC框架包括阿里巴巴的Dubbo,Google的gRPC等,这里我们模仿Dubbo设计一个Client和Server约定接口和协议,Client远程调用Server提供的服务,提供者返回一个字符串/也可以是其他对象,消费者使用该数据/本次将该数据打印系统
  • 基于Netty 4.1.20版本进行代码实现,依赖相关部署看我之前的博客传送门

    1)创建一个接口,定义相关的抽向方法:用于Client和Server之间的约定;
    2)创建一个Server类,负责监听Client的请求并返回约定数据;
    3)创建一个Client类,该类能够透明的调用远程方法/自己不存在的方法,Client内部使用Netty请求Server返回数据
    在这里插入图片描述

3、系统结构

  • 在Intellij IDEA中新建一个Maven工程,对Maven不熟悉的小伙伴只需要补充如何在Intellij中安装Maven/使用Maven导入相关依赖/查看关系图等基础操作即可,使用pom.xml文件配置Netty依赖/也可以直接使用Maven导入
  • 系统的结构图如下:
    在这里插入图片描述

4、代码实现

1)HelloService接口
  • 接口文件,提供Server和Client都需要
package com.atguigu.netty.dubborpc.publicinterface;
//这个是接口,是服务提供方和 服务消费方都需要
public interface HelloService {
   

    String hello(String mes);
}
2)HelloServiceImpl类
  • 实现HelloService接口,当有Client调用该方法的时候就返回一个结果
package com.atguigu.netty.dubborpc.provider;

import com.atguigu.netty.dubborpc.publicinterface.HelloService;

public class HelloServiceImpl implements HelloService{
   

    private static int count = 0;
    //当有消费方调用该方法时, 就返回一个结果
    @Override
    public String hello(String mes) {
   
        System.out.println("收到客户端消息=" + mes);
        //根据mes 返回不同的结果
        if(mes != null) {
   
            return "你好客户端, 我已经收到你的消息 [" + mes + "] 第" + (++count) + " 次";
        } else {
   
            return "你好客户端, 我已经收到你的消息 ";
        }
    }
}

3)NettyServer类
  • Client实现类,关键的是NettyServerHandler,下面有实现代码
package com.atguigu.netty.dubborpc.netty;


import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelPipeline;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioServerSocketChannel;
import io.netty.handler.codec.string.StringDecoder;
import io.netty.handler.codec.string.StringEncoder;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值