新書推薦:
《
这才是真正的诸葛亮
》
售價:HK$
74.8
《
嫉妒
》
售價:HK$
53.9
《
文明的碎片(西蒙·沙玛重磅新作!)
》
售價:HK$
107.8
《
别读博,会脱单
》
售價:HK$
57.2
《
甲骨文丛书·德意志与神圣罗马帝国(第1卷):从马克西米利安一世到《威斯特伐利亚和约》(1493~1648年)(全2册)
》
售價:HK$
260.8
《
强绩效模式:从0到1的绩效架构设计
》
售價:HK$
86.9
《
引爆流量:轻松打造爆款短视频
》
售價:HK$
75.9
《
数学史概论
》
售價:HK$
107.8
|
內容簡介: |
本书为了让读者扎稳高性能基础,浅显易懂地剖析高并发IO的底层原理,细致细腻地解析Reactor高性能模式,图文并茂地介绍Java异步回调模式。掌握这些基础原理,能够帮助读者解决Java后台开发的一些实际问题。
本书共12章,主要介绍高性能通信框架Netty,并详尽介绍Netty的EventLoop、Handler、Pipeline、ByteBuf、Decoder、Encoder等重要组件,然后介绍单体IM的实战设计和模块实现。本书对ZooKeeper、 Curator API、Redis、Jedis API的使用也进行详尽的介绍,让读者具备高并发、可扩展系统的设计和开发能力。
|
目錄:
|
前言
第1章高并发时代的必备技能1
1.1Netty为何这么火1
1.1.1Netty火热的程度1
1.1.2Netty是面试的必杀器2
1.2高并发利器Redis2
1.2.1什么是Redis2
1.2.2Redis成为缓存事实标准的原因3
1.3分布式利器ZooKeeper3
1.3.1什么是ZooKeeper3
1.3.2ZooKeeper的优势4
1.4高并发IM的综合实践4
1.4.1高并发IM的学习价值4
1.4.2庞大的应用场景5
1.5Netty、Redis、ZooKeeper实践计划5
1.5.1第1天:Java NIO实践5
1.5.2第2天:Reactor反应器模式实践6
1.5.3第3天:异步回调模式实践7
1.5.4第4天:Netty基础实践8
1.5.5第5天:解码器(Decoder)与编码器(Encoder)实践9
1.5.6第6天:JSON和ProtoBuf序列化实践11
1.5.7第7~10天:基于Netty的单聊实战12
1.5.8第11天:ZooKeeper实践计划14
1.5.9第12天:Redis实践计划14
1.6本章小结16
第2章高并发IO的底层原理17
2.1IO读写的基础原理17
2.1.1内核缓冲区与进程缓冲区18
2.1.2详解典型的系统调用流程18
2.2四种主要的IO模型19
2.2.1同步阻塞IO(Blocking IO)20
2.2.2同步非阻塞NIO(None Blocking IO)21
2.2.3IO多路复用模型(IO Multiplexing)22
2.2.4异步IO模型(Asynchronous IO)23
2.3通过合理配置来支持百万级并发连接24
2.4本章小结26
第3章Java NIO通信基础详解27
3.1Java NIO简介27
3.1.1NIO和OIO的对比28
3.1.2通道(Channel)28
3.1.3Selector 选择器28
3.1.4缓冲区(Buffer)29
3.2详解NIO Buffer类及其属性29
3.2.1Buffer类29
3.2.2Buffer类的重要属性29
3.2.34个属性的小结31
3.3详解NIO Buffer类的重要方法31
3.3.1allocate创建缓冲区31
3.3.2put写入到缓冲区32
3.3.3flip翻转33
3.3.4get从缓冲区读取34
3.3.5rewind倒带35
3.3.6mark 和reset 37
3.3.7clear 清空缓冲区38
3.3.8使用Buffer类的基本步骤38
3.4详解NIO Channel(通道)类38
3.4.1Channel(通道)的主要类型39
3.4.2FileChannel文件通道39
3.4.3使用FileChannel完成文件复制的实践案例41
3.4.4SocketChannel套接字通道42
3.4.5使用SocketChannel发送文件的实践案例44
3.4.6DatagramChannel数据报通道46
3.4.7使用DatagramChannel数据包通道发送数据的实践案例47
3.5详解NIO Selector选择器49
3.5.1选择器以及注册49
3.5.2SelectableChannel可选择通道50
3.5.3SelectionKey选择键50
3.5.4选择器使用流程50
3.5.5使用NIO实现Discard服务器的实践案例52
3.5.6使用SocketChannel在服务器端接收文件的实践案例54
3.6本章小结57
第4章鼎鼎大名的Reactor反应器模式59
4.1Reactor反应器模式为何如此重要59
4.1.1为什么首先学习Reactor反应器模式59
4.1.2Reactor反应器模式简介60
4.1.3多线程OIO的致命缺陷60
4.2单线程Reactor反应器模式62
4.2.1什么是单线程Reactor反应器62
4.2.2单线程Reactor反应器的参考代码63
4.2.3一个Reactor反应器版本的EchoServer实践案例65
4.2.4单线程Reactor反应器模式的缺点67
4.3多线程的Reactor反应器模式68
4.3.1多线程池Reactor反应器演进68
4.3.2多线程Reactor 反应器的实践案例68
4.3.3多线程Handler处理器的实践案例70
4.4Reactor反应器模式小结72
4.5本章小结73
第5章并发基础中的Future异步回调模式74
5.1从泡茶的案例说起74
5.2join异步阻塞75
5.2.1线程的join合并流程75
5.2.2使用join实现异步泡茶喝的实践案例75
5.2.3详解join合并方法77
5.3FutureTask异步回调之重武器77
5.3.1Callable接口77
5.3.2初探FutureTask类78
5.3.3Future接口79
5.3.4再探FutureTask类79
5.3.5使用FutureTask类实现异步泡茶喝的实践案例80
5.4Guava的异步回调82
5.4.1详解FutureCallback82
5.4.2详解ListenableFuture83
5.4.3ListenableFuture异步任务84
5.4.4使用Guava实现泡茶喝的实践案例84
5.5Netty的异步回调模式87
5.5.1详解GenericFutureListener接口87
5.5.2详解Netty的Future接口88
5.5.3ChannelFuture的使用88
5.5.4Netty的出站和入站异步回调89
5.6本章小结90
第6章Netty原理与基础91
6.1第一个Netty的实践案例DiscardServer91
6.1.1创建第一个Netty项目91
6.1.2第一个Netty服务器端程序92
6.1.3业务处理器NettyDiscardHandler93
6.1.4运行NettyDiscardServer94
6.2解密Netty中的Reactor反应器模式95
6.2.1回顾Reactor反应器模式中IO事件的处理流程95
6.2.2Netty中的Channel通道组件96
6.2.3Netty中的Reactor 反应器96
6.2.4Netty中的Handler处理器97
6.2.5Netty的流水线(Pipeline)98
6.3详解Bootstrap启动器类100
6.3.1
|
內容試閱:
|
移动时代、5G时代、物联网时代的大幕已经开启,它们对于高性能、高并发的开发知识和技术的要求,抬升了Java工程师的学习台阶和面试门槛。
大公司的面试题从某个侧面映射出生产场景中对专项技术的要求。高并发的面试题以前基本是BAT等大公司的专利,现在几乎蔓延至与Java项目相关的整个行业。例如,与Java NIO、Reactor模式、高性能通信、分布式锁、分布式ID、分布式缓存、高并发架构等技术相关的面试题,从以前的加分题变成了现在的基础题,这也映射出开发Java项目所必需的技术栈:分布式Java框架、Redis缓存、分布式搜索ElasticSearch、分布式协调ZooKeeper、消息队列Kafka、高性能通信框架Netty。
本书内容
本书的内容源于疯狂创客圈社群的博客,以及社群持续迭代的CrazyIM项目,虽然书中重在讲解Netty、Redis、ZooKeeper的使用方法,但是还有一个更大的价值,就是为大家打下Java高并发开发技术的坚实基础。
首先,本书从操作系统的底层原理开始讲解:浅显易懂地剖析高并发IO的底层原理,并介绍如何让单体Java应用支持百万级的高并发;从传统的阻塞式OIO开始,细致地解析Reactor高性能模式,介绍高性能网络开发的基础知识;从Java的线程Join和线程池开始,介绍Java Future和Guava ListenableFuture两种常用异步回调技术。这些原理方面的基础知识非常重要,是大家在日常开发Java后台应用时解决实际问题的金钥匙。
接着,重点讲解Netty。这是目前当之无愧的高性能通信框架皇冠上的明珠,是支撑其他众多著名的高并发、分布式、大数据框架底层的框架。这里有两大特色:一是从Reactor模式入手,以四两拨千斤的方式来学习Netty原理;二是通过Netty来解决网络编程中的重点难题,如ProtoBuf序列化问题、半包问题等。
然后,对ZooKeeper进行详细的介绍。除了全面地介绍使用Curator API操作ZooKeeper之外,还从实战的角度出发,介绍如何使用ZooKeeper来设计分布式ID生成器,并对重要的SnowFlake算法进行详细的介绍。另外,还通过图文并茂和结合小故事的方式浅显易懂地介绍分布式锁的基本原理,并完成一个ZooKeeper分布式锁的小实践案例。
接下来,从实践开发层面对Redis进行说明,详细介绍Redis的5种数据类型、客户端操作指令、Jedis Java API。另外,还通过spring-data-redis来完成两种方式的数据分布式缓存,并详尽地介绍Spring的缓存注解以及涉及的SpEL表达式语言。
最后,通过CrazyIM项目介绍一个亿级流量的高并发IM系统模型。这个高并发架构的系统模型不仅仅限于IM系统,通过简单的调整和适配,就可以应用于当前主流的Java后台系统。
读者对象
(1)对Java NIO、高性能IO、高并发编程感兴趣的大专院校学生。
(2)需要学习Java高并发技术、高并发架构的初、中级Java工程师。
(3)生产项目中需要用到Netty、Redis、ZooKeeper三大框架的架构师或者项目人员。
本书源代码下载
本书的源代码可以从https:gitee.comsfasdfasdfsdfnetty_redis_zookeeper_source_code.git下载。另外,还可以登录机械工业出版社华章公司网站(www.hzbook.com)下载,先搜索到本书,然后在页面上的资料下载模块下载即可。如果下载有问题,请发送电子邮件至booksaga@126.com,邮件主题为求Netty、Redis、ZooKeeper高并发实战下载资源
勘误和支持
由于作者水平和能力有限,不妥之处在所难免,希望读者批评指正。本书的读者QQ群为104131248,目前群中已经包含了不少高质量的面试题以及开发技术难题,欢迎读者入群进行交流。
致谢
写书,不仅仅是一项技术活,而且是一项工匠活,为了确保书中知识的全面性、系统性,我需要不断地思考与总结。为了保证书中的每一行程序都是正确的,我需要反复地编写LLT用例去进行验证。总之,一本优质的书,意味着需要牺牲陪伴家人的大量时间。感谢我的妻子、孩子们给我一贯的支持和帮助!
感谢卞诚君老师在我写书过程中给予的指导和帮助。没有他的提议,我不会想到将自己发布在疯狂创客圈社群中高并发方面的博客文章整理成一本书出版。另外,还让我感觉到写博客和写书不是一个层面的事情。博客里的很多内容是不全面、不严谨的,甚至是错误的。
感谢疯狂创客圈社群中的小伙伴们,虽然你们的很多技术难题,我不一定能给出最佳的解答方案,但正是因为一路同行,一直坦诚、纯粹的技术交流,大家相互启发了许多技术灵感,拓展了彼此的技术视野,最终提升了水平。欢迎大家来砸问题,也欢迎大家多多交流。
尼恩
中国武汉
|
|