温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么用 Netty 实现简单的 RPC

发布时间:2021-07-21 11:20:37 来源:亿速云 阅读:136 作者:chen 栏目:云计算

本篇内容主要讲解“怎么用 Netty 实现简单的 RPC”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用 Netty 实现简单的 RPC”吧!


1、需求

模仿 dubbo,消费者和提供者约定接口和协议,消费者远程调用提供者,提供者返回一个字符串,消费者打印提供者返回的数据。底层网络通信使用 Netty 4.1.16。

2、设计

  1. 创建一个接口,定义抽象方法。用于消费者和提供者之间的约定。

  2. 创建一个提供者,该类需要监听消费者的请求,并按照约定返回数据。

  3. 创建一个消费者,该类需要透明的调用自己不存在的方法,内部需要使用 Netty 请求提供者返回数据。

3、 实现

1. 创建 maven 项目,导入 Netty 4.1.16。

<groupId>cn.thinkinjava</groupId><artifactId>rpc-demo</artifactId><version>1.0-SNAPSHOT</version><dependencies>   <dependency>     <groupId>io.netty</groupId>     <artifactId>netty-all</artifactId>     <version>4.1.16.Final</version>   </dependency></dependencies>

2. 项目目录结构如下:

怎么用 Netty 实现简单的 RPC

3. 设计接口

===============

一个简单的 hello world:

public interface HelloService {	String hello(String msg);}

4. 提供者相关实现

==================

4.1. 首先实现约定接口,用于返回客户端数据:

/** * 实现类 */public class HelloServiceImpl implements HelloService { public String hello(String msg) { return msg != null ? msg + " -----> I am fine." : "I am fine."; }}

4.2. 实现 Netty 服务端和自定义 handler

启动 Netty Server 代码:

private static void startServer0(String hostName, int port) {    try {     ServerBootstrap bootstrap = new ServerBootstrap();     NioEventLoopGroup eventLoopGroup = new NioEventLoopGroup();     bootstrap.group(eventLoopGroup)         .channel(NioServerSocketChannel.class)         .childHandler(new ChannelInitializer<SocketChannel>() {            @Override           protected void initChannel(SocketChannel ch) throws Exception {             ChannelPipeline p = ch.pipeline();             p.addLast(new StringDecoder());             p.addLast(new StringEncoder());             p.addLast(new HelloServerHandler());           }         });     bootstrap.bind(hostName, port).sync();   } catch (InterruptedException e) {     e.printStackTrace();   } }

上面的代码中添加了 String类型的编解码 handler,添加了一个自定义 handler。

自定义 handler 逻辑如下:

/*** 用于处理请求数据*/public class HelloServerHandler extends ChannelInboundHandlerAdapter {  @Override public void channelRead(ChannelHandlerContext ctx, Object msg) {    // 如何符合约定,则调用本地方法,返回数据   if (msg.toString().startsWith(ClientBootstrap.providerName)) {     String result = new HelloServiceImpl()         .hello(msg.toString().substring(msg.toString().lastIndexOf("#") + 1));     ctx.writeAndFlush(result);   } }}

这里显示判断了是否符合约定(并没有使用复杂的协议,只是一个字符串判断),然后创建一个具体实现类,并调用方法写回客户端。为什么Netty这么火?为什么?

还需要一个启动类:

public class ServerBootstrap {  public static void main(String[] args) {   NettyServer.startServer("localhost", 8088); }}

好,关于提供者的代码就写完了,主要就是创建一个 netty 服务端,实现一个自定义的 handler,自定义 handler 判断是否符合之间的约定(算是协议吧),如果符合,就创建一个接口的实现类,并调用他的方法返回字符串。

5. 消费者相关实现

消费者有一个需要注意的地方,就是调用需要透明,也就是说,框架使用者不用关心底层的网络实现。这里我们可以使用 JDK 的动态代理来实现这个目的。

思路:客户端调用代理方法,返回一个实现了 HelloService 接口的代理对象,调用代理对象的方法,返回结果。

我们需要在代理中做手脚,当调用代理方法的时候,我们需要初始化 Netty 客户端,还需要向服务端请求数据,并返回数据。

5.1. 首先创建代理相关的类

public class RpcConsumer {  private static ExecutorService executor = Executors     .newFixedThreadPool(Runtime.getRuntime().availableProcessors());  private static HelloClientHandler client;  /**  * 创建一个代理对象  */ public .........

到此,相信大家对“怎么用 Netty 实现简单的 RPC”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI