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接口
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);
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 {