不会Netty,你永远是个Java菜鸟
👆点击“博文视点Broadview”,获取更多书讯
Netty是互联网中间件、大数据领域使用最广泛、最核心的网络通信框架。
由下图可以看到,几乎所有互联网中间件、大数据框架均使用了Netty,掌握Netty是一名初中级工程师迈向中高级工程师所需的最重要的技能之一。
然而,目前市面上对初学者友好的Netty资料较少,网络上大多数技术博客都是一堆零散的知识点集合,无法串成一条线形成一个体系。
俞超老师(闪电侠)在多年的Netty实战、调优、“踩坑”过程中积累了丰富的经验,持续在网络上分享的相关博客、视频等有100W+阅读量,并得到网友一致好评!
为了将这部分经验系统地分享给大家,帮助大家提升核心竞争力,俞超老师特地将Netty底层原理相关知识进行系统梳理,写作了《跟闪电侠学 Netty:Netty 即时聊天实战与底层原理》一书!
本书上篇通过一个即时聊天的例子,让读者能够系统地使用一遍Netty,全面掌握Netty的知识点;下篇通过对源码的层层剖析,让读者能够掌握Netty底层原理,知其然并知其所以然,从而编写出高性能网络应用程序。
在入门实战篇中,读者跟随笔者实践完这个即时聊天系统后,能够学会如何使用Netty完成最基本的网络通信程序,可以掌握以下知识点:
1. 如何启动服务端?
2. 如何启动客户端?
3. 如何设计长连自定义协议?
4. 拆包/粘包原理与实践。
5. 如何实现自定义编解码。
6. 如何使用Pipeline与ChannelHandler?
7. 心跳与空闲检测的方法。
8. 如何性能调优?
本篇通俗易懂,可一口气读完,让你一周内进入实战!
在源码分析篇中,笔者从用户视角出发,环环相扣,带领读者逐个攻破Netty底层原理,掌握以下知识点:
1. 服务端启动流程:ServerBootstrap外观,创建NioServerSocketChannel,初始化,注册Selector,绑定端口,接收新连接。
2. 高并发线程模型:Netty无锁化串行设计,精心设计的Reactor线程模型榨干CPU、打满网卡、让应用程序性能爆表的底层原理。
3. 新连接接入流程:Boss Reactor线程,监测新连接,创建NioSocketChannel,IO线程分配,Selector注册事件。
4. 解码原理:解码顶层抽象,定长解码器,行解码器,分隔符解码器,基于长度域解码器全面分析。
5. 事件传播机制脉络:大动脉Pipeline,处理器ChannelHandler,Inbound和Outbound事件传播与异常传播的原理,编码原理。
6. writeAndFlush流程:深入了解使用最频繁的writeAndFlush的底层原理,避免踩坑。
本书适合以下三类人群:
1. 如果你听说过或简单使用过Netty,想全面系统地学习Netty,并掌握一些性能调优方法,本书的入门实战篇可以帮助你达成这个目标。
2. 如果你深度使用过Netty,想深入了解Netty的底层设计,编写出更灵活高效的网络通信程序,本书的源码分析篇可以帮助你达成这个目标。
3. 如果你从未读过开源框架源码,本书将是你的第一本源码指导书,阅读优秀的开源软件源码可以助你写出更优美的程序。读源码并不难,难的是迈出这一小步,之后就能通往更广阔的空间。
01. 按章节顺序把入门实战篇的代码一章章敲出来,在没有掌握前一章节的知识点之前,建议不要跳跃学习。
02. 入门实战篇学完之后,合上书本,把本书即时聊天系统的代码再整体敲若干遍,敲的过程中可能会发现自己有遗忘知识点,这个时候可能需要不断翻阅书本,没有关系,翻阅就好了。
03. 确保最后一次实现本书的即时聊天系统的例子是没有翻阅书本的,是完全自行实现的,之后进入源码分析篇的学习。
04. 针对源码分析篇,建议读者按章节顺序来学习,不要跳跃,不要图快,每一步都要扎实。
05. 在源码学习的过程中,先跟随书本,对照源码,把对应章节的流程过一遍,每个章节学完之后,建议花较多的时间进行调试和阅读,确保掌握了前一章节的内容之后再进行下一章的学习。
本书作者闪电侠同学,多年在研发一线,在平时的工作中对Netty的钻研非常深入,在公司内作为核心技术骨干,不仅仅解决本团队的技术难题,也帮助其他团队解决相关技术疑难杂症。很荣幸能成为最早的阅读者之一,这本书深入浅出、言简意赅,通过一个通信程序的案例介绍了Netty的基础知识,并通过源码分析介绍了Netty的底层原理,希望给各位读者带来帮助。
——美团前技术总监 & 比心技术CTO 尤勇
Netty是业界卓越的开源大作!第一次使用时,我就被它的高吞吐和高性能所折服。JBoss开源的Netty网络框架是CAT服务端除JDK外唯一的外部依赖,表现不俗,生产环境物理机上几张千兆网卡经常可以满负荷运转,多核CPU可以保持100%运行,让CAT的单机吞吐能力最高达到45万MPS,消息平均大小约1KB。我强烈建议大家使用Netty,当然我们也踩过几个坑,需要合理使用,希望本书对大家理解和使用Netty网络编程有所帮助。
——平安银行零售首席架构师 吴其敏
曾几何时,Mina很火,然而当Netty横空出世的时候,却抢尽了风头。作为高性能领域的杰出代表,Netty成为很多RPC框架底层通信的标配,闪电侠的这本书从典型的通信场景——聊天室出发,深入浅出地剖析了Netty的源码,对于想写出高性能代码的读者来说,非常值得借鉴,值得一读。
——HeapDump性能社区发起人 & PerfMa CEO你假笨
闪电侠是个精力充沛的技术大牛,花了大量的业余时间投身于开源代码和撰写技术博客。在美团工作期间,我有幸与闪电侠合作多年,一起搭建了美团重要的网络基础设施,并凭借该项目一举拿下了美团的年度最高技术奖项。在分工合作上,我负责前端,闪电侠负责后端。他当时对Netty技术非常痴迷,将通信框架进行大量重构,使得性能获得极大提升,此外还进行了大量的技术创新,来保障通信高性能和系统稳定运行。更难能可贵的是,他还撰写了很多关于Netty的研究心得文章。现在,这些宝贵经验已经集结成书,强烈建议所有对Netty技术或高性能网络技术感兴趣的技术人员阅读。
——平安银行前端架构领域负责人 周辉
在异步编程模型上,Netty无疑是值得学习和研究的NIO框架。作者从原理和案例实战的角度出发,全面介绍了Netty的使用。本书条理清晰,对技术的阐述循序渐进,囊括了Netty所涉及的NIO、Selector模型、线程模型、网络协议等诸多核心技术,强烈建议大家阅读学习。
——《高可用可伸缩微服务架构》作者 程超
本书沉淀了笔者自身多年研发实践和进阶心得,通过精巧设计的案例,将网络通信、并发编程的重点知识与具体场景结合起来,让读者快速入门,掌握生产级别的Netty开发技能。与此同时,完整、系统化的源码分析,也能够使工程师有效提升底层技术能力,形成良好的工程素养。相信这些一手修炼心得会让开发者受益匪浅,非常适合想要入门或者进阶Netty开发的初、中级工程师。
——Oracle前首席工程师 杨晓峰
闪电侠,某互联网公司技术专家。精通Netty、Spring、MyBatis 等开源框架。负责公司各类长连项目的开发与维护,有千万级别实时在线连接、百亿吞吐长连通信经验。Vim和IDEA党,对效率和编写优美代码有极致的追求。
简书“Netty源码分析”专栏作者。
异常火爆的慕课“IntelliJ IDEA神器使用技巧”作者。
慕课“Netty源码分析视频教程”作者。
微信公众号:闪电侠的博客。
热文推荐
▼点击阅读原文,了解本书详情~