从 RocketMQ 学 Netty 网络编程技巧

举报
丁威 发表于 2021/04/18 02:18:18 2021/04/18
【摘要】 从整个类体系看网络设计 RocketMQ 关于网络方面核心类图如下所示: 接下来先一一介绍各个类的主要职责。 RemotingService RPC 远程服务基础类。主要定义所有的远程服务类的基础方法: void start():启动远程服务。 void shutdown():关闭。 void registerRPCHook(RPCHook rpcHoo...

从整个类体系看网络设计

RocketMQ 关于网络方面核心类图如下所示:

1

接下来先一一介绍各个类的主要职责。

RemotingService

RPC 远程服务基础类。主要定义所有的远程服务类的基础方法:

  • void start():启动远程服务。
  • void shutdown():关闭。
  • void registerRPCHook(RPCHook rpcHook):注册 RPC 钩子函数,有利于在执行网络操作的前后执行定制化逻辑。

RemotingServer/RemotingClient

远程服务器/客户端基础接口,两者中的方法基本类似,故这里重点介绍一下 RemotingServer,定位 RPC 远程操作的相关“业务方法”。


  
  1. void registerProcessor(int requestCode, NettyRequestProcessor processor,ExecutorService executor)

注册命令处理器,这里是 RocketMQ Netty 网络设计的核心亮点,RocketMQ 会按照业务逻辑进行拆分ÿ

文章来源: blog.csdn.net,作者:中间件兴趣圈,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/prestigeding/article/details/109335913

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。