內(nèi)容簡(jiǎn)介
這是一部全面解析Java異步編程的著作,針對(duì)各種常見(jiàn)異步編程場(chǎng)景,從編程語(yǔ)言、開(kāi)發(fā)框架等角度深入講解了異步編程的原理和方法。作者是淘寶的資深Java技術(shù)工程師,在Java異步編程、并發(fā)編程領(lǐng)域有深厚的積累。
全書(shū)共9章,每章內(nèi)容概括如下:
第1-2章主要介紹了異步編程的概念、適用場(chǎng)景,以及如何使用線(xiàn)程和線(xiàn)程池來(lái)實(shí)現(xiàn)異步編程;
第3章首先講解JDK中的各種Future及其內(nèi)部實(shí)現(xiàn)原理,然后講解如何使用Future實(shí)現(xiàn)異步編程,以及如何結(jié)合JDK8 Stream 和Future實(shí)現(xiàn)異步編程;
第4章講解了Spring框架中提供的異步執(zhí)行能力,包含Spring中如何對(duì)TaskExecutor進(jìn)行抽象,如何使用注解@Async實(shí)現(xiàn)異步編程,以及其內(nèi)部實(shí)現(xiàn)原理;
第5章講解了比較熱門(mén)的反應(yīng)式編程相關(guān)的內(nèi)容,包含什么是反應(yīng)式編程,如何使用反應(yīng)式編程規(guī)范的庫(kù)RxJava和Reactor庫(kù)實(shí)現(xiàn)異步編程;
第6章講解了Web Servlet的異步非阻塞處理,包含Servlet 3.0規(guī)范是如何提供異步處理能力的,Servlet 3.1規(guī)范是如何解決IO阻塞問(wèn)題的,以及在Spring MVC中如何進(jìn)行異步處理。
第7章講解與Servlet技術(shù)棧并行存在的、由Spring5.0提出來(lái)的Spring WebFlux的異步非阻塞處理,包含Spring WebFlux的由來(lái)、Spring WebFlux的并發(fā)模型、兩種編程模型,以及如何使用Spring WebFlux來(lái)進(jìn)行服務(wù)開(kāi)發(fā)、Spring WebFlux內(nèi)部的實(shí)現(xiàn)原理。
第8章簡(jiǎn)要介紹了業(yè)界為方便實(shí)現(xiàn)異步編程而設(shè)計(jì)的一些框架和中間件,比如異步基于事件驅(qū)動(dòng)的網(wǎng)絡(luò)編程框架Netty,高性能RPC框架Apache Dubbo,高性能線(xiàn)程間消息傳遞庫(kù)Disruptor,異步基、分布式、基于事件驅(qū)動(dòng)的編程框架Akka,高性能分布式消息平臺(tái)Apache RocketMQ 。
第9章介紹新興的Go語(yǔ)言是如何從語(yǔ)言層面提供了強(qiáng)大的異步編程能力的。
本書(shū)注重理論與實(shí)踐相結(jié)合,且每個(gè)異步技術(shù)點(diǎn)都附有代碼實(shí)例,幫助讀者加深理解。
(1)作者是淘寶的資深Java研發(fā)工程師,在Java異步編程和并發(fā)編程領(lǐng)域積累了豐富的經(jīng)驗(yàn)。
(2)本書(shū)得到了周志明、李運(yùn)華、毗盧、于君澤、方騰飛等Java技術(shù)領(lǐng)域的資深專(zhuān)家的一致好評(píng)和推薦。
(3)本書(shū)從JDK、Spring、Web Servlet、Netty、Dubbo、Go語(yǔ)言等框架和語(yǔ)言的角度全面講解了異步編程的原理和技巧,以及異步編程各種常見(jiàn)的適用常見(jiàn)。
(4)注重實(shí)戰(zhàn),每個(gè)技術(shù)知識(shí)點(diǎn)都配有案例代碼。
為何寫(xiě)作本書(shū)
異步編程是可以讓程序并行運(yùn)行的一種手段,可以讓程序中的一個(gè)工作單元與主應(yīng)用程序線(xiàn)程分開(kāi)獨(dú)立運(yùn)行,進(jìn)而提高應(yīng)用程序的性能和響應(yīng)能力等。
雖然Java為不同技術(shù)域提供了相應(yīng)的異步編程技術(shù),但是這些異步編程技術(shù)被散落到不同技術(shù)域的技術(shù)文檔中,沒(méi)有一個(gè)統(tǒng)一的文檔對(duì)其進(jìn)行梳理歸納。另外這些技術(shù)之間是什么關(guān)系,各自的出現(xiàn)都是為了解決什么問(wèn)題,我們也很難找到相關(guān)資料來(lái)解釋。
本書(shū)的出現(xiàn)則是為了打破這種局面,旨在對(duì)Java中相關(guān)的異步編程技術(shù)進(jìn)行歸納總結(jié),為讀者提供一個(gè)統(tǒng)一文檔來(lái)查閱、參考。
本書(shū)特色
本書(shū)涵蓋了Java中常見(jiàn)的異步編程場(chǎng)景,包括單JVM內(nèi)的異步編程、跨主機(jī)通過(guò)網(wǎng)絡(luò)通信的遠(yuǎn)程過(guò)程調(diào)用的異步調(diào)用與異步處理,以及Web請(qǐng)求的異步處理等。
本書(shū)在講解Java中每種異步編程技術(shù)時(shí)都附有案例,以理論與實(shí)踐相結(jié)合的方式,幫助讀者更好地掌握相關(guān)內(nèi)容。
書(shū)中在講解每種異步編程技術(shù)時(shí)多會(huì)對(duì)其實(shí)現(xiàn)原理進(jìn)行講解,讓讀者知其然也知其所以然。
對(duì)于最近比較熱門(mén)的反應(yīng)式編程以及WebFlux的使用與原理解析,本書(shū)也有一定的深入探索。
本書(shū)讀者對(duì)象
本書(shū)適用于有一定Java編程基礎(chǔ),并對(duì)Java并發(fā)編程、Java異步編程、反應(yīng)式編程感興趣的讀者。
如何閱讀本書(shū)
對(duì)于初學(xué)者,建議按照本書(shū)編寫(xiě)的章節(jié)順序進(jìn)行學(xué)習(xí),因?yàn)楸緯?shū)是按照從易到難的順序編寫(xiě)的,并且每章都有一些代碼示例供大家動(dòng)手實(shí)踐,以便加深理解。如果你對(duì)Java并發(fā)編程與異步編程有一定的了解,那么可以直接從目錄查看感興趣的章節(jié)進(jìn)行學(xué)習(xí)。本書(shū)共分為9章,內(nèi)容概述如下:
第1章主要講解異步編程的概念和作用,以及在日常開(kāi)發(fā)中都有哪些異步編程場(chǎng)景。
第2章講解最基礎(chǔ)的顯式使用線(xiàn)程和線(xiàn)程池來(lái)實(shí)現(xiàn)異步編程的方法,也分析了它們目前存在的缺點(diǎn)。
第3章內(nèi)容比較豐富,主要講解JDK中的各種Future,包括如何使用Future實(shí)現(xiàn)異步編程及其內(nèi)部實(shí)現(xiàn)原理,然后講解了如何結(jié)合JDK8 Stream 和Future實(shí)現(xiàn)異步編程。
第4章講解Spring框架中提供的異步執(zhí)行能力,包括在Spring中如何對(duì)TaskExecutor進(jìn)行抽象,如何使用注解@Async實(shí)現(xiàn)異步編程,以及其內(nèi)部實(shí)現(xiàn)原理。
第5章講解比較熱門(mén)的反應(yīng)式編程相關(guān)的內(nèi)容,包括什么是反應(yīng)式編程,如何使用反應(yīng)式編程規(guī)范的庫(kù)RxJava和Reactor實(shí)現(xiàn)異步編程。
第6章講解Web Servlet的異步非阻塞處理,包括Servlet 3.0規(guī)范是如何提供異步處理能力的,Servlet 3.1規(guī)范是如何解決IO阻塞問(wèn)題的,以及如何在Spring MVC進(jìn)行異步處理。
第7章講解與Servlet技術(shù)棧并行存在的、由Spring5.0提出的Spring WebFlux異步非阻塞處理,包括Spring WebFlux的由來(lái)、Spring WebFlux的并發(fā)模型、兩種編程模型,以及如何使用Spring WebFlux來(lái)進(jìn)行服務(wù)開(kāi)發(fā)、Spring WebFlux內(nèi)部的實(shí)現(xiàn)原理。
第8章簡(jiǎn)要介紹了業(yè)界為方便實(shí)現(xiàn)異步編程而設(shè)計(jì)的一些框架和中間件,比如異步基于事件驅(qū)動(dòng)的網(wǎng)絡(luò)編程框架Netty,高性能RPC框架Apache Dubbo,高性能線(xiàn)程間消息傳遞庫(kù)Disruptor,異步、分布式、基于事件驅(qū)動(dòng)的編程框架Akka和高性能分布式消息框架Apache RocketMQ。
第9章介紹新興的Go語(yǔ)言是如何從語(yǔ)言層面提供強(qiáng)大的異步編程能力的。
資源和勘誤
有需要的讀者可以到https://github.com/zhailuxu/async-program-demo 下載本書(shū)的demo資源,由于筆者水平有限,如果你在閱讀本書(shū)時(shí)發(fā)現(xiàn)錯(cuò)誤,可以把錯(cuò)誤信息提交到華章網(wǎng)站(www.hzbook.com)。
致謝
首先要感謝機(jī)械工業(yè)出版社楊福川老師的團(tuán)隊(duì),他們擁有豐富的出版經(jīng)驗(yàn),在本書(shū)的命名以及目錄結(jié)構(gòu)調(diào)整上,給出了很多中肯的建議;其次要感謝我的家人,感謝他們對(duì)我的鼓勵(lì)與支持,讓我有充分的時(shí)間來(lái)寫(xiě)作本書(shū)。
翟陸續(xù)(花名:加多)
資深Java研發(fā)工程師,就職于淘寶,有多年的Java研發(fā)經(jīng)驗(yàn),在Java并發(fā)編程、異步編程等方面有深入研究和積累。對(duì)JUC包源碼有深入的理解,熟悉常用開(kāi)源框架實(shí)現(xiàn)原理。
著有暢銷(xiāo)書(shū)《Java并發(fā)編程之美》。
前言
第1章 認(rèn)識(shí)異步編程1
1.1 異步編程概念與作用1
1.2 異步編程場(chǎng)景2
1.3 總結(jié)9
第2章 顯式使用線(xiàn)程和線(xiàn)程池實(shí)現(xiàn)異步編程10
2.1 顯式使用線(xiàn)程實(shí)現(xiàn)異步編程10
2.2 顯式使用線(xiàn)程池實(shí)現(xiàn)異步編程14
2.2.1 如何顯式使用線(xiàn)程池實(shí)現(xiàn)異步編程14
2.2.2 線(xiàn)程池ThreadPoolExecutor原理剖析17
2.3 總結(jié)34
第3章 基于JDK中的Future實(shí)現(xiàn)異步編程35
3.1 JDK 中的Future35
3.2 JDK中的FutureTask37
3.2.1 FutureTask 概述37
3.2.2 FutureTask的類(lèi)圖結(jié)構(gòu)41
3.2.3 FutureTask的run() 方法45
3.2.4 FutureTask的get()方法48
3.2.5 FutureTask的cancel(boolean mayInterruptIfRunning)方法50
3.2.6 FutureTask的局限性52
3.3 JDK中的CompletableFuture52
3.3.1 CompletableFuture 概述52
3.3.2 顯式設(shè)置CompletableFuture結(jié)果54
3.3.3 基于CompletableFuture實(shí)現(xiàn)異步計(jì)算與結(jié)果轉(zhuǎn)換56
3.3.4 多個(gè)CompletableFuture進(jìn)行組合運(yùn)算65
3.3.5 異常處理68
3.3.6 CompletableFuture概要原理70
3.4 JDK8 Stream & CompletableFuture76
3.4.1 JDK8 Stream76
3.4.2 當(dāng)Stream遇見(jiàn)CompletableFuture79
3.5 總結(jié)81
第4章 Spring框架中的異步執(zhí)行82
4.1 Spring中對(duì)TaskExecutor的抽象82
4.2 如何在Spring中使用異步執(zhí)行84
4.2.1 使用TaskExecutor實(shí)現(xiàn)異步執(zhí)行84
4.2.2 使用注解@Async實(shí)現(xiàn)異步執(zhí)行89
4.3 @Async注解異步執(zhí)行原理96
4.4 總結(jié)109
第5章 基于反應(yīng)式編程實(shí)現(xiàn)異步編程110
5.1 反應(yīng)式編程概述110
5.2 Reactive Streams規(guī)范120
5.3 基于RxJava實(shí)現(xiàn)異步編程123
5.4 基于Reactor實(shí)現(xiàn)異步編程133
5.5 總結(jié)136
第6章 Web Servlet的異步非阻塞處理137
6.1 Servlet概述137
6.2 Servlet 3.0 提供的異步處理能力138
6.3 Servlet 3.1 提供的非阻塞IO能力145
6.4 Spring Web MVC 的異步處理能力153
6.4.1 基于DeferredResult的異步處理154
6.4.2 基于Callable實(shí)現(xiàn)異步處理155
6.5 總結(jié)157
第7章 Spring WebFlux的異步非阻塞處理158
7.1 Spring WebFlux概述158
7.2 Reactive編程 & Reactor庫(kù)159
7.3 WebFlux服務(wù)器160
7.4 WebFlux的并發(fā)模型163
7.5 WebFlux對(duì)性能的影響164
7.6 WebFlux的編程模型164
7.6.1 WebFlux注解式編程模型165
7.6.2 WebFlux函數(shù)式編程模型168
7.7 WebFlux原理淺嘗171
7.7.1 Reactor Netty概述171
7.7.2 WebFlux服務(wù)器啟動(dòng)流程173
7.7.3 WebFlux一次服務(wù)調(diào)用流程182
7.8 WebFlux的適用場(chǎng)景185
7.9 總結(jié)186
第8章 高性能異步編程框架和中間件187
8.1 異步、基于事件驅(qū)動(dòng)的網(wǎng)絡(luò)編程框架Netty187
8.1.1 Netty概述187
8.1.2 Netty的線(xiàn)程模型190
8.1.3 TCP半包與粘包問(wèn)題196
8.1.4 基于Netty與CompletableFuture實(shí)現(xiàn)RPC異步調(diào)用198
8.2 高性能RPC框架Apache Dubbo209
8.2.1 Apache Dubbo概述209
8.2.2 Dubbo的異步調(diào)用210
8.2.3 Dubbo的異步執(zhí)行214
8.3 高性能線(xiàn)程間消息傳遞庫(kù)Disruptor217
8.3.1 Disruptor概述217
8.3.2 Disruptor的特性詳解220
8.3.3 基于Disruptor實(shí)現(xiàn)異步編程223
8.4 異步、分布式、基于消息驅(qū)動(dòng)的框架Akka227
8.4.1 Akka概述227
8.4.2 傳統(tǒng)編程模型存在的問(wèn)題228
8.4.3 Actor模型解決了傳統(tǒng)編程模型的問(wèn)題232
8.4.4 基于Akka實(shí)現(xiàn)異步編程237
8.5 高性能分布式消息框架Apache RocketMQ244
8.5.1 Apache RocketMQ概述244
8.5.2 基于Apache RocketMQ實(shí)現(xiàn)系統(tǒng)間異步解耦246
8.6 總結(jié)254
第9章 Go語(yǔ)言的異步編程能力255
9.1 Go語(yǔ)言概述255
9.2 Go語(yǔ)言的線(xiàn)程模型256
9.2.1 一對(duì)一模型256
9.2.2 多對(duì)一模型257
9.2.3 多對(duì)多模型258
9.2.4 Go語(yǔ)言的線(xiàn)程模型259
9.3 goroutine與channel261
9.3.1 goroutine261
9.3.2 channel265
9.3.3 構(gòu)建管道實(shí)現(xiàn)異步編程269
9.4 總結(jié)273