你将获得
- 掌握 Netty 的
核心运行流程
,可以对其进行二次开发; - 掌握多种高性能
数据结构、算法和优化策略,以及设计模式的使用思想
; - 掌握池化技术,体会
无锁化思想
,增强自身内功修炼; - 对并发编程有更深的理解和体会,可以借鉴 Netty 的
异步模式
,设计并发任务的执行方案; - 基于 Netty 构建其他
高性能的网络框架
; - 能快速定位 Netty 项目中的
BUG 和故障
; - 通过 Netty 理解
编程思想的应用
,为今后学习其他框架源码打下基础。
作者介绍
陈清风扬,某互联网公司后端团队技术负责人,负责公司海外线上培训项目,及 Clare Chatbot 聊天机器人项目。热爱编程,喜欢钻研技术,尤其喜欢钻研各种框架源码,对 Java 后端相关的流行框架都有过深入研究,如 Spring、MyBatis、Redis 等等。
小册介绍
你见过手写 Netty 吗?
可能见过,可能几分钟前刚刚见过。
但你见过足足 20 个版本的手写 Netty 代码吗?
在网络编程中,Netty 一般是大家首选的通信框架。它性能十分优秀,功能也非常丰富,使用起来却很简单。但是,想要真正精通 Netty 并不容易
。
首先,想要入门 Netty,网上有很多免费的学习资料供我们选择,但它们大多比较零碎不全面,还需要我们耗时去搜集补充。
其次,很多关于 Netty 的教学资料都是以分析源码的方式讲解的,但经常是当时看懂了,过段时间忘了再看,再看再忘,总感觉没有掌握透。
最后,很多人自学源码之后,只知道 Netty 是这么设计编写的,要这么设计编写,却不知道为什么,而这恰恰是我们最应该掌握的。
我认为,学习一个框架最好的方法就是仿写一个。
因此,这本小册将在源码剖析的基础上,带大家手写一个 Netty。那么,这个手写有什么特别之处呢?
我们会通过由浅入深的方式,系统讲解、归纳 Netty 中所有有价值的知识点。比如异步与回调的编程思想、各种设计模式、Reactor 线程模型、各种高性能的数据结构、时间轮、对象池、内存分配、内存池、内存泄漏检测,编解码等等。
随着学习的不断深入,我们每一个阶段都会手写一版 Netty,不断为其增加新的功能,由简到繁,最终实现一个完整的 Netty(和 Netty 源码一致)。总的来说,代码一共会有 20 个版本
,每一个版本中的所有类的所有方法
都会有详细注释,学习曲线十分平缓。
同时,我也会通过一些小例子循序渐进的引导大家,讲清楚 Netty 为什么是这样编写,而不是直接告诉大家就这样写。最终,通过一步一步实现、对比不同版本的 Netty,帮助大家真正掌握 Netty。
基于此,小册从内容上可以划分为 3 个模块
。
基础结构篇
:第 1 到第 7 节。详细分析 Netty 的基础结构、类和接口的关系,搭建最基础的架子。在这个模块大家可以深刻体会那些最基础的编程思想,是怎么在框架中发挥作用的
。流程详解篇
:第 8 到第 16 节。基于搭好的架子填充各种内容,使它真正丰满起来。在这个模块大家会学到一些数据结构和设计模式的运用方式,彻底掌握 Netty 的运行流程。掌握了这个模块的内容,在工作中定位 bug,甚至是对 Netty 进行二次开发
,都能游刃有余。性能优化篇
:第 17 到第 34 节。会在之前的基础上,对一些重要方法进行重构和优化,并且引入新的知识体系。这个模块是课程的重中之重。高性能无锁队列、时间轮、对象池、内存分配、内存池
都会在这一部分得到实现。
以下是小册核心内容的思维导图:
最后,我们这本小册,是以渐进的方式手写 Netty 框架,会从最基础的 Reactor 线程模型讲到复杂的内存池实现
,希望我的这种写作方式能被大家认可,真正帮助到有需要的人!
适宜人群
- RPC 框架开发、服务器开发以及消息中间件开发的从业者;
- 掌握基础并发编程和 BIO、NIO 知识,想进阶学习的开发者;
- 只熟悉 Netty 简单使用,想全面了解 Netty 内部架构的开发者;
- 常年 CRUD,对 Java 编程、网络编程和操作系统底层知识了解不深入,想要深入学习的开发者。