前言
Netty将Java NIO接口封装,提供了全异步编程方式,是各大Java项目的网络应用开发必备神器。
在本文中,将Netty学习者咨询的相关问题,进行了归纳和总结,以问题案例做牵引,通过对案例进行剖析,讲解问题背后的原理,并结合Netty源码分析,让读者能够真正掌握Netty,在实际工作中少犯错。
本文中的案例涵盖了Netty 的启动和停止、内存、并发多线程、性能、可靠性、安全等方面,囊括了Netty绝大多数常用的功能及容易让人犯错的地方。在案例的分析过程中,还穿插讲解了Netty的问题定位思路、方法、技巧,以及解决问题使用的相关工具,对读者在实际工作中用好Netty具有很大的帮助和启发作用。
本文将从前言、目录、主要内容包括的章节、专家推荐和适合本文读者四部分内容给大家进行介绍,希望大家能仔细阅读,理解其中的真谛,真真正正的掌握Netty这门技术,希望大家能够喜欢!!
目录
主要内容
第1章Netty服务端意外退出案例;本章通过两个简单的案例分析,引出了信号量、Java Daemon 线程及Netty 优雅退出相关知识。在实际项目中,知识往往是交叉在一起的,要想熟练掌握Netty服务端的启动和退出,编写更优雅和健壮的代码,需要重点掌握如下几个知识点:
(1)操作系统的信号量和JavaDeamon线程工作机制。
(2) Netty 的NioEventLoop线程工作原理。
(3) Netty 优雅退出相关的几个核心类库。
第3章Netty内存池泄漏疑云案例;Netty内存池是一把双刃剑,使用得当会在很大程度上提升系统的性能,但是误用则会带来内存泄漏问题。从表面上看,只要遵循主动申请和释放原则即可,但是由于内存的申请和释放可能由Netty框架隐性完成,增加了内存管理的复杂性。
通过学习Netty 收发消息的ByteBuf 申请和释放机制,可以避免在项目中因误用ByteBuf而发生内存泄漏。在熟悉了ByteBuf的申请和释放机制后,通过对Netty内存池工作原理和关键源码的分析,读者可以更好地掌握Netty内存池的使用方法。
第6章API网关高并发压测性能波动案例;对于高并发接入的API网关类产品,需要谨慎处理消息的内存申请和释放,减少不必要的申请(例如透传类场景),同时要防止内存空间的浪费。借鉴Netty请求消息读取的内存申请策略和动态扩容机制,并用在实际项目中,可以得到较大的性能提升。
第7章Netty ChannelHandler并发安全案例;ChannelHandler是用户最常用的接口,掌握了ChannelHandler 及ChannelPipeline 工作原理,就清楚了什么时候该使用共享的ChannelHandler,什么时候该对ChannelHandler做并发保护。无论缺少保护还是过度保护,都会给业务带来副作用,甚至严重的功能或性能问题,因此ChannelHandler的并发安全性是非常重要的。
第16章Netty流量整形应用案例;流量整形与流控的最大区别在于,流控会拒绝消息,流量整形不拒绝和丢弃消息,无论接收量多大,它总能以近似恒定的速度下发消息,跟变压器的原理和功能类似。
专家推荐和适合本文读者
本文适合架构师、设计师、开发工程师、测试工程师,以及对Java NIO框架、Netty感兴趣的其他相关人士阅读。
希望大家能够仔细揣摩本文的所有内容,争取都能够完全掌握甚至精通,这样子不至于在今后的社会中处于劣势状态,永远走在前面,也希望大家能够推陈出新,形成自己的一套知识框架。
大家加油努力学习吧!!