netty.3.9.4.Final源码的精简版本:Simple Netty Source

jopen 9年前

本项目是netty.3.9.4.Final源码的精简版本,删除掉netty中不必要的功能,只保留了核心模块,方便进行源码学习。

//TODO

  • 进一步以方法为粒度对源码做精简(目前仅以模块粒度进行源码精简)

模块变更

以下的表格列出了保留的模块

Modules Function
bootstrap 组织netty模块工作并启动相关模块的工具类
buffer Buffer的具体相关实现
channel 对java nio中的channel的重新封装的相关实现
channel-socket netty的网络核心模块,包括Boss、Worker、Selector、核心主循环等相关实现
logging(不重要) 相关的log工具类实现
util(不重要) 相关的工具类实现,包括Timer、StringUtil、ByteBufferUtil等

注:其中logging和util并不重要,阅读源码时可以略过,这里由于一些依赖关系所以保留

以下表格列出了删除掉的模块

Modules Function
channel-group Channel Group相关实现
channel-local local transport的相关支持
channel-socket-http http handler的相关实现
channel-socket-oio oio模式下的核心网络模块
container 一些无关紧要的适配
example Netty官方自带的一些例子
handler Netty异常强大功能全面的handler实现
netty-test Netty的单元测试集

源码阅读指南

由于netty模块内部的对象协作关系较为复杂,所以这里推荐从最为简单的EchoServer作为入口阅读相关源码。(Example代码已经附在了test中)

关键源码阅读路径

  • new NioServerSocketChannelFactory() ====> new NioWorkerPool() ====> AbstractNioWorkerPool.init() ====> AbstractNioWorkerPool.newWorker(Executor) ====> NioWorkerPool.createWorker(Executor) ====> new AbstractNioSelector(Executor, ThreadNameDeterminer) ====> AbstractNioSelector.openSelector(ThreadNameDeterminer)
  • new NioServerSocketChannelFactory() ====> new NioServerBossPool() ====> NioServerBossPool.init() ====> AbstractNioBossPool.newBoss(Executor) ====> NioServerBossPool.newBoss(Executor) ====> new NioServerBoss(Executor, ThreadNameDeterminer) ====> AbstractNioSelector.openSelector(ThreadNameDeterminer)
  • AbstractNioSelector.run() ====> AbstractNioSelector.process()
  • AbstractNioSelector.run() ====> NioServerBoss.process()
  • AbstractNioSelector.run() ====> AbstractNioSelector.processTaskQueue()

注意事项

在阅读过程中需要注意以下几点:

  • NioWorker和NioServerBoss分别是Worker和Boss的线程runnable实现,Netty的核心nio网络处理代码就在这两个类以及其相关父类中
  • 顺着ServerBootstrap的创建,就可以摸清楚NioWorker和NioServerBoss是如何被创建,如何run起来的
  • NioWorker和NioServerBoss中的firexxx一系列方法即为触发channelPipeline寻找已添加的handler分发对应的事件的入口方法
  • DefaultChannelPipeline实现了ChannelPipeline,其中以链表维护具体的handler列表。具体事件的分发分为两个方向,即upStream和downStream,前者代表read事件的分发,后者代表write事件的分发
  • buffer包中为ChannelBuffer的相关实现,在NioWorker中的process方法的read调用里面可以清晰看到ChannelBuffer的创建和分发的upStream的具体过程。
  • ChannelBuffer的实现主要去看ChannelBuffer -> AbstractChannelBuffer -> HeapChannelBuffer -> BigEndianHeapChannelBuffer这条线即可
  • 善于在关键路径运用断点查看调用栈,一目了然

项目主页:http://www.open-open.com/lib/view/home/1414743328731