返回首页
苏宁会员
购物车 0
易付宝
手机苏宁

服务体验

店铺评分与同行业相比

用户评价:----

物流时效:----

售后服务:----

  • 服务承诺: 正品保障
  • 公司名称:
  • 所 在 地:

  • 正版书籍 Netty进阶之路:跟着案例学Netty 9787121352621 电子工业出版社
    • 作者: 李林锋著
    • 出版社: 电子工业出版社
    • 出版时间:2018-01-01 00:00:00
    送至
  • 由""直接销售和发货,并提供售后服务
  • 加入购物车 购买电子书
    服务

    看了又看

    商品预定流程:

    查看大图
    /
    ×

    苏宁商家

    商家:
    君凤文轩图书专营店
    联系:
    • 商品

    • 服务

    • 物流

    搜索店内商品

    商品分类

    商品参数
    • 作者: 李林锋著
    • 出版社:电子工业出版社
    • 出版时间:2018-01-01 00:00:00
    • 版次:1
    • 页数:340
    • 开本:其他
    • 装帧:平装
    • ISBN:9787121352621
    • 国别/地区:中国
    • 版权提供:电子工业出版社

    基本信息

    书名:Netty进阶之路:跟着案例学Netty

    定价:79.00元

    作者:李林锋

    出版社:电子工业出版社

    出版日期:2018-11-01

    ISBN:9787121352621

    字数:

    页码:

    版次:1

    装帧:平装-胶订

    开本:16开

    商品重量:0.4kg

    编辑推荐


    精选自1000多个一线业务实际案例,从原理到实践全景式讲解Netty项目实践,快速领悟Netty专家花大量时间积累的经验,提高编程水平及分析解决问题的能力,《Netty木又威指南》作者力作,众专家力荐。

    Netty是Java高性能网络编程的明星框架

    在阿里等互联网公司Netty是程序员必须掌握的基础组件

    现有Netty图书多是讲解其实现及原理的,缺少对实际应用的指导

    在实际使用中遇到Netty故障,需要花大量实践摸索、试验解决

    本书作者经过多年的积累,将遇到的问题进行分门别类的讲解

    连接池资源泄漏、服务端意外退出、高并发性能波动及IoT海量连接等

    除了描述问题的前因后果,还讲解了问题定位的各种思路和方法

    以及对于Netty关键技术的剖许,再加上作者酣畅淋漓的文风

    可以让你快速领悟到Netty专家花大量时间积累的经验

    对于提高编程水平及分析解决问题的能力大有帮助

    内容提要


    Netty将Java NIO接口封装,提供了全异步编程方式,是各大Java项目的网络应用开发神器。本书作者是Netty技术的先行者和布道者,本书是他继《Netty指南》之后的又一力作。在本书中,作者将在过去几年实践中遇到的问题,以及Netty学习者咨询的相关问题,进行了归纳和总结,以问题案例做牵引,通过对案例进行剖析,讲解问题背后的原理,并结合Netty源码分析,让读者能够真正掌握Netty,在实际工作中少犯错。本书中的案例涵盖了Netty的启动和停止、内存、并发多线程、性能、可靠性、安全等方面,囊括了Netty绝大多数常用的功能及容易让人犯错的地方。在案例的分析过程中,还穿插讲解了Netty的问题定位思路、方法、技巧,以及解决问题使用的相关工具,对读者在实际工作中用好Netty具有很大的帮助和启发作用。本书适合架构师、设计师、开发工程师、测试工程师,以及对Java NIO框架、Netty感兴趣的其他相关人士阅读。

    目录


    第1章 Netty服务端意外退出案例1
    1.1 Netty服务端意外退出问题1
    1.1.1 Java Daemon线程简介2
    1.1.2 Netty服务端启动原理4
    1.1.3 如何防止Netty服务端意外退出6
    1.1.4 实际项目中的优化策略8
    1.2 Netty优雅退出机制9
    1.2.1 Java优雅退出机制10
    1.2.2 Java优雅退出的注意点12
    1.2.3 Netty优雅退出机制14
    1.2.4 Netty优雅退出原理和源码分析15
    1.2.5 Netty优雅退出的一些误区20
    1.3 总结21
    第2章 Netty客户端连接池资源泄漏案例22
    2.1 Netty连接池资源泄漏问题22
    2.1.1 连接池创建代码23
    2.1.2 内存溢出和线程膨胀23
    2.1.3 错用NIO编程模式25
    2.1.4 正确的连接池创建方式26
    2.1.5 并发安全和资源释放28
    2.2 Netty客户端创建机制29
    2.2.1 Java NIO客户端创建原理分析29
    2.2.2 Netty客户端创建原理分析32
    2.2.3 Bootstrap工具类源码分析34
    2.3 总结36
    第3章 Netty内存池泄漏疑云案例37
    3.1 Netty内存池泄漏问题37
    3.1.1 路由转发服务代码38
    3.1.2 响应消息内存释放玄机39
    3.1.3 采集堆内存快照分析42
    3.1.4 ByteBuf申请和释放的理解误区45
    3.2 Netty内存池工作机制48
    3.2.1 内存池的性能优势48
    3.2.2 内存池工作原理分析51
    3.2.3 内存池核心代码分析54
    3.3 总结58
    第4章 ByteBuf故障排查案例59
    4.1 协议栈ByteBuf使用问题59
    4.1.1 响应Body获取异常59
    4.1.2 ByteBuf非法引用问题63
    4.1.3 ByteBuf使用注意事项66
    4.2 Netty ByteBuf实现机制67
    4.2.1 Java原生ByteBuffer的局限性67
    4.2.2 Netty ByteBuf工作原理分析67
    4.2.3 ByteBuf引用计数器工作原理和源码分析70
    4.3 总结73
    第5章 Netty发送队列积压导致内存泄漏案例74
    5.1 Netty发送队列积压案例74
    5.1.1 高并发故障场景74
    5.1.2 内存泄漏原因分析76
    5.1.3 如何防止发送队列积压78
    5.1.4 其他可能导致发送队列积压的因素80
    5.2 Netty消息发送工作机制82
    5.2.1 WriteAndFlushTask原理和源码分析83
    5.2.2 ChannelOutboundBuffer原理和源码分析86
    5.2.3 消息发送源码分析88
    5.2.4 消息发送高低水位控制94
    5.3 总结95
    第6章 API网关高并发压测性能波动案例96
    6.1 高并发压测性能波动问题96
    6.1.1 故障场景模拟96
    6.1.2 性能波动原因定位98
    6.1.3 主动内存泄漏定位法101
    6.1.4 网关类产品的优化建议102
    6.2 Netty消息接入内存申请机制102
    6.2.1 消息接入的内存分配原理和源码分析102
    6.2.2 Netty ByteBuf的动态扩容原理和源码分析107
    6.3 总结108
    第7章 Netty ChannelHandler并发安全案例109
    7.1 Netty ChannelHandler并发安全问题109
    7.1.1 串行执行的ChannelHandler110
    7.1.2 跨链路共享的ChannelHandler114
    7.1.3 ChannelHandler的并发陷阱116
    7.2 Netty ChannelHandler工作机制118
    7.2.1 职责链ChannelPipeline原理和源码分析118
    7.2.2 用户自定义Event原理和源码分析122
    7.3 总结123
    第8章 车联网服务端接收不到车载终端消息案例124
    8.1 车联网服务端接收不到车载终端消息问题124
    8.1.1 故障现象125
    8.1.2 故障期线程堆栈快照分析126
    8.1.3 NioEventLoop线程防挂死策略128
    8.2 NioEventLoop线程工作机制129
    8.2.1 I/O读写操作原理和源码分析130
    8.2.2 异步任务执行原理和源码分析133
    8.2.3 定时任务执行原理和源码分析135
    8.2.4 Netty多线程实践137
    8.3 总结137
    第9章 Netty 3.X版本升级案例139
    9.1 Netty 3.X的版本升级背景139
    9.1.1 被迫升级场景140
    9.1.2 升级不当遭遇各种问题140
    9.2 版本升级后数据被篡改问题141
    9.2.1 数据篡改原因分析142
    9.2.2 问题总结143
    9.3 升级后上下文丢失问题143
    9.3.1 上下文丢失原因分析144
    9.3.2 依赖第三方线程模型的思考144
    9.4 升级后应用遭遇性能下降问题145
    9.4.1 性能下降原因分析145
    9.4.2 性能优化建议146
    9.5 Netty线程模型变更分析147
    9.5.1 Netty 3.X版本线程模型147
    9.5.2 Netty 4.X版本线程模型149
    9.5.3 线程模型变化点源码分析150
    9.5.4 线程模型变化总结152
    9.6 总结154
    第10章 Netty并发失效导致性能下降案例155
    10.1 业务ChannelHandler无法并发执行问题155
    10.1.1 服务端并发设计相关代码分析155
    10.1.2 无法并行执行的EventExecutorGroup159
    10.1.3 并行执行优化策略和结果161
    10.2 Netty DefaultEventExecutor工作机制163
    10.2.1 DefaultEventExecutor原理和源码分析164
    10.2.2 业务线程池优化策略165
    10.2.3 Netty线程绑定机制原理和源码分析168
    10.3 总结170
    第11章 IoT百万长连接性能调优案例171
    11.1 海量长连接接入面临的挑战171
    11.1.1 IoT设备接入特点172
    11.1.2 IoT服务端性能优化场景172
    11.1.3 服务端面临的性能挑战172
    11.2 智能家居内存泄漏问题173
    11.2.1 服务端内存泄漏原因定位173
    11.2.2 问题背后的一些思考174
    11.3 操作系统参数调优174
    11.3.1 文件描述符175
    11.3.2 TCP/IP相关参数175
    11.3.3 多网卡队列和软中断177
    11.4 Netty性能调优177
    11.4.1 设置合理的线程数177
    11.4.2 心跳优化180
    11.4.3 接收和发送缓冲区调优183
    11.4.4 合理使用内存池184
    11.4.5 防止I/O线程被意外阻塞185
    11.4.6 I/O线程和业务线程分离187
    11.4.7 针对端侧并发连接数的流控187
    11.5 JVM相关性能优化189
    11.5.1 GC调优189
    11.5.2 其他优化手段193
    11.6 总结193
    第12章 静态检查修改不当引起性能下降案例195
    12.1 Edge Service性能严重下降问题195
    12.1.1 Edge Service热点代码分析195
    12.1.2 静态检查问题不是简单的一改了之197
    12.1.3 问题反思和改进200
    12.2 克隆和浅拷贝201
    12.2.1 浅拷贝存在的问题201
    12.2.2 Netty的对象拷贝实现策略203
    12.3 总结204
    第13章 Netty性能统计误区案例205
    13.1 时延毛刺排查相关问题205
    13.1.1 时延毛刺问题初步分析205
    13.1.2 服务调用链改进207
    13.1.3 都是同步思维惹的祸208
    13.1.4 正确的消息发送速度性能统计策略209
    13.1.5 常见的消息发送性能统计误区212
    13.2 Netty关键性能指标采集策略212
    13.2.1 Netty I/O线程池性能指标213
    13.2.2 Netty发送队列积压消息数214
    13.2.3 Netty消息读取速度性能统计215
    13.3 总结215
    第14章 gRPC的Netty /2实践案例216
    14.1 gRPC基础入门216
    14.1.1 RPC框架简介216
    14.1.2 当前主流的RPC框架218
    14.1.3 gRPC框架特点218
    14.1.4 为什么选择/2219
    14.2 gRPC Netty /2服务端工作机制220
    14.2.1 Netty /2服务端创建原理和源码分析220
    14.2.2 服务端接收/2请求消息原理和源码分析224
    14.2.3 服务端发送/2响应消息原理和源码分析231
    14.3 gRPC Netty /2客户端工作机制234
    14.3.1 Netty /2客户端创建原理和源码分析235
    14.3.2 客户端发送/2请求消息原理和源码分析238
    14.3.3 客户端接收/2响应消息原理和源码分析242
    14.4 gRPC消息序列化机制243
    14.4.1 Google Protobuf简介243
    14.4.2 消息的序列化原理和源码分析244
    14.4.3 消息的反序列化原理和源码分析245
    14.5 gRPC线程模型246
    14.5.1 服务端线程模型246
    14.5.2 客户端线程模型247
    14.5.3 线程模型总结248
    14.6 总结249
    第15章 Netty事件触发策略使用不当案例250
    15.1 channelReadComplete方法被调用多次问题250
    15.1.1 ChannelHandler调用问题250
    15.1.2 生产环境问题模拟重现252
    15.2 ChannelHandler使用的一些误区总结255
    15.2.1 channelReadComplete方法调用255
    15.2.2 ChannelHandler职责链调用257
    15.3 总结258
    第16章 Netty流量整形应用案例259
    16.1 Netty流量整形功能259
    16.1.1 通用的流量整形功能简介260
    16.1.2 Netty流量整形功能简介260
    16.2 Netty流量整形应用261
    16.2.1 流量整形示例代码261
    16.2.2 流量整形功能测试263
    16.3 Netty流量整形工作机制264
    16.3.1 流量整形工作原理和源码分析264
    16.3.2 并发编程在流量整形中的应用271
    16.3.3 使用流量整形的一些注意事项总结274
    16.4 总结278
    第17章 Netty SSL应用案例279
    17.1 Netty SSL功能简介279
    17.1.1 SSL安全特性280
    17.1.2 Netty SSL实现机制281
    17.2 Netty客户端SSL握手超时问题282
    17.2.1 握手超时原因定位282
    17.2.2 Netty SSL握手问题定位技巧283
    17.3 SSL握手性能问题284
    17.3.1 SSL握手性能热点分析284
    17.3.2 缓存和对象池285
    17.4 SSL事件监听机制286
    17.4.1 握手成功事件286
    17.4.2 SSL连接关闭事件286
    17.5 总结287
    第18章 Netty S服务端高并发宕机案例288
    18.1 Netty S服务端宕机问题288
    18.1.1 客户端大量超时288
    18.1.2 服务端内存泄漏原因分析289
    18.1.3 NioSocketChannel泄漏原因探究290
    18.1.4 高并发场景下缺失的可靠性保护292
    18.2 功能层面的可靠性优化294
    18.2.1 Netty S服务端可靠性优化295

    作者介绍


    李林锋

    文摘


    序言


    售后保障

    最近浏览

    猜你喜欢

    该商品在当前城市正在进行 促销

    注:参加抢购将不再享受其他优惠活动

    x
    您已成功将商品加入收藏夹

    查看我的收藏夹

    确定

    非常抱歉,您前期未参加预订活动,
    无法支付尾款哦!

    关闭

    抱歉,您暂无任性付资格

    此时为正式期SUPER会员专享抢购期,普通会员暂不可抢购