深刻分析Java Web技術內幕(修訂版)

阿里巴巴集團技術叢書前端

深刻分析Java Web技術內幕(修訂版)(阿里巴巴集團技術叢書。技術大牛範禹、玉伯、畢玄聯協力薦!大型互聯網公司開發應用實踐!程序員

許令波 著   面試

ISBN 978-7-121-23293-0算法

2014年8月出版數據庫

訂價:79.00元 編程

464設計模式

16瀏覽器

編輯推薦緩存

讓讀者知其然,並知其因此然,是《深刻分析Java Web技術內幕(修訂版)》一書最大的特點。安全

做者來自淘寶技術一線,親歷了淘寶網PV從1億到10億的發展歷程,直接經歷了在這個過程當中技術的不斷突破、飛躍等變遷,並積累了豐富實踐經驗。

《深刻分析Java Web技術內幕(修訂版)》正是分享了做者在面臨種種技術問題、技術瓶頸時的思路、方法和技巧,具體的應用實踐和直接的案例。

在此次的修訂版中,做者補充了淘寶網近兩年在無線端的最新的應用實踐。在這個快速發展的移動互聯的時代,這樣直接的技術積累和分享尤爲珍貴。

相信讀者必定能從中獲益匪淺。

阿里巴巴集團技術叢書是抱持着爲工程師服務的理念誕生的。

阿里的快速發展,使咱們有機會見證技術變革的強大力量。在這過程當中,咱們經歷了技術的變遷、興衰、成敗,既有收穫也有教訓。現在,阿里已成爲一家使人矚目的互聯網公司,站在這樣的時點上,回顧過去,放眼四周,咱們深入地以爲有必要將沉澱下來的一線經驗與智慧,結集出版,理由有三。

1.回報。咱們得到的種種經驗與教訓,只有在阿里這樣快速成長、體量巨大的公司中才有機會親歷。這樣的技術環境並非每一個工程師都有機緣遇到的。這些經歷幫助了咱們我的能力的提高,也幫助阿里成爲一家技術實力過硬的公司。咱們願意把這些內容分享出來,幫助即將或已經面臨相似問題的朋友們,若是他們能夠從閱讀中得到一些啓發而少走彎路的話,將是咱們最大的欣慰。

2.交流。在這套叢書裏,咱們一樣會拋出咱們的困惑、問題,藉助叢書的平臺,擴大工程師溝通的圈子,以書會友,共同探索、學習、提升。

3.溫故知新。以結集的形式,將以往的經驗與知識固化下來,既可便於之後查閱,也能夠幫助咱們系統地梳理思路,更爲全面地審視、洞察、並理解過去發生的種種,爲將來的變化作好更充分、紮實的準備。

基於以上的考慮,阿里巴巴集團技術叢書將立足於實踐,着眼於問題,從工程師的視角解讀技術的內涵。

讓思考成爲咱們生活的樂趣,讓閱讀成爲咱們進步的階梯!

內容提要

《深刻分析Java Web技術內幕(修訂版)》新增了淘寶在無線端的應用實踐,包括:CDN 動態加速、多終端化改造、 多終端Session 統一 ,以及在大流量的狀況下,如何跨越性能、網絡和一個地區的電力瓶頸等內容,並提供了比較完整的解決方案。

《深刻分析Java Web技術內幕(修訂版)》主要圍繞Java Web 相關技術從三方面全面、深刻地進行了闡述。首先介紹前端知識,即在JavaWeb 開發中涉及的一些基本知識,包括Web 請求過程、HTTP、DNS 技術和CDN 技術。其次深刻介紹了Java 技術,包括I/O 技術、中文編碼問題、Javac 編譯原理、class 文件結構解析、ClassLoader 工做機制及JVM 的內存管理等。最後介紹了Java 服務端技術,主要包括Servlet、Session 與Cookie、Tomcat 與Jetty服務器、Spring 容器、iBatis 框架和Velocity 框架等原理介紹,並介紹了服務端的一些優化技術。

《深刻分析Java Web技術內幕(修訂版)》不只介紹這些技術和框架的工做原理,並且結合示例來說解,經過通俗易懂的文字和豐富、生動的配圖,讓讀者充分並深刻理解它們的內部工做原理,同時還結合了設計模式來介紹這些技術背後的架構思惟。

目錄

第1章  深刻Web請求過程         1

1.1  B/S網絡架構概述 2

1.2  如何發起一個請求        4

1.3  HTTP解析      6

1.3.1  查看HTTP信息的工具      8

1.3.2  瀏覽器緩存機制         9

1.4  DNS域名解析        12

1.4.1  DNS域名解析過程     12

1.4.2  跟蹤域名解析過程    15

1.4.3  清除緩存的域名         18

1.4.4  幾種域名解析方式    19

1.5  CDN工做機制        20

1.5.1  CDN架構    20

1.5.2  負載均衡    21

1.5.3  CDN動態加速    24

1.6  總結        25

第2章  深刻分析Java I/O的工做機制      26

2.1  Java的I/O類庫的基本架構         26

2.1.1  基於字節的I/O操做接口 27

2.1.2  基於字符的I/O操做接口 28

2.1.3  字節與字符的轉化接口    29

2.2  磁盤I/O工做機制         30

2.2.1  幾種訪問文件的方式         30

2.2.2  Java訪問磁盤文件    34

2.2.3  Java序列化技術         35

2.3  網絡I/O工做機制         37

2.3.1  TCP狀態轉化     38

2.3.2  影響網絡傳輸的因素         40

2.3.3  Java Socket的工做機制     40

2.3.4  創建通訊鏈路    41

2.3.5  數據傳輸    42

2.4  NIO的工做方式    42

2.4.1  BIO帶來的挑戰 42

2.4.2  NIO的工做機制 43

2.4.3  Buffer的工做方式      46

2.4.4  NIO的數據訪問方式 48

2.5  I/O調優 50

2.5.1  磁盤I/O優化      50

2.5.2  TCP網絡參數調優     51

2.5.3  網絡I/O優化      53

2.6  設計模式解析之適配器模式        57

2.6.1  適配器模式的結構    57

2.6.2  Java I/O中的適配器模式  58

2.7  設計模式解析之裝飾器模式        58

2.7.1  裝飾器模式的結構    59

2.7.2  Java I/O中的裝飾器模式  59

2.8  適配器模式與裝飾器模式的區別        60

2.9  總結        60

第3章  深刻分析Java Web中的中文編碼問題         61

3.1  幾種常見的編碼格式   61

3.1.1  爲何要編碼    61

3.1.2  如何「翻譯」    62

3.2  在Java中須要編碼的場景  64

3.2.1  在I/O操做中存在的編碼 64

3.2.2  在內存操做中的編碼         66

3.3  在Java中如何編解碼  67

3.3.1  按照ISO-8859-1編碼          69

3.3.2  按照GB2312編碼      70

3.3.3  按照GBK編碼    71

3.3.4  按照UTF-16編碼        71

3.3.5  按照UTF-8編碼 72

3.3.6  UTF-8編碼代碼片斷  72

3.3.7  對幾種編碼格式的比較    74

3.4  在Java Web中涉及的編解碼       74

3.4.1  URL的編解碼     76

3.4.2  HTTP Header的編解碼      79

3.4.3  POST表單的編解碼   79

3.4.4  HTTP BODY的編解碼         80

3.5  在JS中的編碼問題       81

3.5.1  外部引入JS文件        81

3.5.2  JS的URL編碼    82

3.5.3  其餘須要編碼的地方         84

3.6  常見問題分析        84

3.6.1  中文變成了看不懂的字符         84

3.6.2  一個漢字變成一個問號    85

3.6.3  一個漢字變成兩個問號    85

3.6.4  一種不正常的正確編碼    86

3.7  一種繁簡轉換的實現方式   87

3.8  總結        88

第4章  Javac編譯原理        89

4.1  Javac是什麼 90

4.2  Javac編譯器的基本結構      90

4.3  Javac工做原理分析      92

4.3.1  詞法分析器         93

4.3.2  語法分析器         100

4.3.3  語義分析器         105

4.3.4  代碼生成器         115

4.4  設計模式解析之訪問者模式        118

4.4.1  訪問者模式的結構    119

4.4.2  Javac中訪問者模式的實現       120

4.5  總結        121

第5章  深刻class文件結構        122

5.1  JVM指令集簡介   122

5.1.1  與類相關的指令         124

5.1.2  方法的定義         125

5.1.3  屬性的定義         126

5.1.4  其餘指令集         127

5.2  class文件頭的表示形式       135

5.3  常量池   139

5.3.1  UTF8常量類型   142

5.3.2  Fieldref、Methodref常量類型  143

5.3.3  Class常量類型   143

5.3.4  NameAndType常量類型    144

5.4  類信息   144

5.5  Fields和Methods定義 145

5.6  類屬性描述   149

5.7  Javap生成的class文件結構        150

5.7.1  LineNumberTable         152

5.7.2  LocalVariableTable       153

5.8  總結        155

第6章  深刻分析ClassLoader工做機制   156

6.1  ClassLoader類結構分析       157

6.2  ClassLoader的等級加載機制       158

6.3  如何加載class文件      161

6.3.1  加載字節碼到內存    161

6.3.2  驗證與解析         163

6.3.3  初始化Class對象      163

6.4  常見加載類錯誤分析   163

6.4.1  ClassNotFoundException    163

6.4.2  NoClassDefFoundError        164

6.4.3  UnsatisfiedLinkError   165

6.4.4  ClassCastException     166

6.4.5  ExceptionInInitializerError  167

6.5  經常使用的ClassLoader分析      168

6.6  如何實現本身的ClassLoader       172

6.6.1  加載自定義路徑下的class文件       172

6.6.2  加載自定義格式的class文件  174

6.7  實現類的熱部署   176

6.8  Java應不該該動態加載類   178

6.9  總結        179

第7章  JVM體系結構與工做方式     180

7.1  JVM體系結構        180

7.1.1  何謂JVM    180

7.1.2  JVM體系結構詳解    183

7.2  JVM工做機制        185

7.2.1  機器如何執行代碼    185

7.2.2  JVM爲什麼選擇基於棧的架構    186

7.2.3  執行引擎的架構設計         187

7.2.4  執行引擎的執行過程         188

7.2.5  JVM方法調用棧         193

7.3  總結        197

第8章  JVM內存管理          198

8.1  物理內存與虛擬內存   199

8.2  內核空間與用戶空間   200

8.3  在Java中哪些組件須要使用內存       201

8.3.1  Java堆         201

8.3.2  線程    201

8.3.3  類和類加載器    202

8.3.4  NIO      202

8.3.5  JNI        203

8.4  JVM內存結構        203

8.4.1  PC寄存器   204

8.4.2  Java棧         204

8.4.3  堆         205

8.4.4  方法區         205

8.4.5  運行時常量池    206

8.4.6  本地方法棧         206

8.5  JVM內存分配策略        206

8.5.1  一般的內存分配策略         207

8.5.2  Java中的內存分配詳解    207

8.6  JVM內存回收策略        212

8.6.1  靜態內存分配和回收         212

8.6.2  動態內存分配和回收         213

8.6.3  如何檢測垃圾    213

8.6.4  基於分代的垃圾收集算法         215

8.7  內存問題分析        224

8.7.1  GC日誌分析       224

8.7.2  堆快照文件分析         227

8.7.3  JVM Crash日誌分析  227

8.8  實例1     233

8.9  實例2     235

8.10  實例3  237

8.11  總結      242

第9章  Servlet工做原理解析     243

9.1  從Servlet容器提及       243

9.1.1  Servlet容器的啓動過程    244

9.1.2  Web應用的初始化工做    247

9.2  建立Servlet實例  249

9.2.1  建立Servlet對象        250

9.2.2  初始化Servlet    250

9.3  Servlet體系結構   252

9.4  Servlet如何工做   255

9.5  Servlet中的Listener      257

9.6  Filter如何工做       259

9.7  Servlet中的url-pattern          261

9.8  總結        262

第10章  深刻理解Session與Cookie 263

10.1  理解Cookie 264

10.1.1  Cookie屬性項  264

10.1.2  Cookie如何工做       265

10.1.3  使用Cookie的限制 268

10.2  理解Session         269

10.2.1  Session與Cookie      269

10.2.2  Session如何工做      270

10.3  Cookie安全問題 273

10.4  分佈式Session框架    274

10.4.1  存在哪些問題  274

10.4.2  能夠解決哪些問題  275

10.4.3  整體實現思路  275

10.5  Cookie壓縮 280

10.6  表單重複提交問題      282

10.7  多終端Session統一    283

10.8  總結      285

第11章  Tomcat的系統架構與設計模式  286

11.1  Tomcat整體設計         286

11.1.1  Tomcat整體結構      287

11.1.2  Connector組件         293

11.1.3  Servlet容器Container      298

11.1.4  Tomcat中的其餘組件      309

11.2  Tomcat中的設計模式         309

11.2.1  門面設計模式  309

11.2.2  觀察者設計模式       311

11.2.3  命令設計模式  313

11.2.4  責任鏈設計模式       314

11.3  總結      316

第12章  Jetty的工做原理解析  317

12.1  Jetty的基本架構         317

12.1.1  Jetty基本架構簡介 317

12.1.2  Handler的體系結構         319

12.2  Jetty的啓動過程         320

12.3  接受請求      321

12.3.1  基於HTTP工做         321

12.3.2  基於AJP工做   323

12.3.3  基於NIO方式工做  326

12.4  處理請求      327

12.5  與JBoss集成       330

12.6  與Tomcat的比較        331

12.6.1  架構比較  331

12.6.2  性能比較  332

12.6.3  特性比較  332

12.7  總結      333

第13章  Spring框架的設計理念與設計模式分析    334

13.1  Spring的骨骼架構       334

13.1.1  Spring的設計理念   335

13.1.2  核心組件如何協同工做  336

13.2  核心組件詳解      337

13.2.1  Bean組件 337

13.2.2  Context組件     339

13.2.3  Core組件 340

13.2.4  Ioc容器如何工做     342

13.3  Spring中AOP的特性詳解  352

13.3.1  動態代理的實現原理       352

13.3.2  Spring AOP如何實現        355

13.4  設計模式解析之代理模式 358

13.4.1  代理模式原理  358

13.4.2  Spring中代理模式的實現        358

13.5  設計模式解析之策略模式 361

13.5.1  策略模式原理  361

13.5.2  Spring中策略模式的實現        362

13.6  總結      362

第14章  Spring MVC的工做機制與設計模式   364

14.1  Spring MVC的整體設計      364

14.2  Control設計         369

14.2.1  HandlerMapping初始化  370

14.2.2  HandlerAdapter初始化   372

14.2.3  Control的調用邏輯 373

14.3  Model設計  374

14.4  View設計     375

14.5  框架設計的思考 377

14.5.1  爲何須要框架       377

14.5.2  須要什麼樣的框架  377

14.5.3  框架設計原則  378

14.5.4 「指航燈」         378

14.5.5  最基本的原則  378

14.6  設計模式解析之模板模式 379

14.6.1  模板模式的結構       379

14.6.2  Spring MVC中的模板模式示例       379

14.7  總結      380

第15章  深刻分析iBatis框架之系統架構與映射原理    381

15.1  iBatis框架主要的類層次結構   381

15.2  iBatis框架的設計策略        382

15.3  iBatis框架的運行原理        384

15.4  示例      386

15.5  iBatis對SQL語句的解析    388

15.6  數據庫字段映射到Java對象     389

15.7  示例運行的結果 391

15.8  設計模式解析之簡單工廠模式 391

15.8.1  簡單工廠模式的實現原理       391

15.8.2  iBatis中的簡單工廠模式示例         392

15.9  設計模式解析之工廠模式 393

15.9.1  工廠模式的實現原理       393

15.9.2  iBatis中的工廠模式示例         394

15.10  總結   395

第16章  Velocity工做原理解析 397

16.1  Velocity整體架構         398

16.2  JJTree渲染過程解析  401

16.2.1  #set語法  405

16.2.2  Velocity的方法調用          406

16.2.3  #if、#elseif和#else語法 409

16.2.4  #foreach語法   410

16.2.5  #parse語法       412

16.3  事件處理機制      413

16.4  經常使用優化技巧      416

16.4.1  減小樹的總節點數量       416

16.4.2  減小渲染耗時的節點數量       416

16.5  與JSP比較  417

16.5.1  JSP渲染機制    417

16.5.2  Velocity與JSP   423

16.6  設計模式解析之合成模式 423

16.6.1  合成模式的結構       423

16.6.2  Velocity中合成模式的實現     424

16.7  設計模式解析之解釋器模式      425

16.7.1  解釋器模式的結構  425

16.7.2  Velocity中解釋器模式的實現          426

16.8  總結      426

第17章  Velocity優化實踐 427

17.1  現實存在的問題 427

17.2  優化的理論基礎 428

17.2.1  程序語言的三角形結構  428

17.2.2  數據結構減小抽象化       429

17.2.3  簡單的程序複雜化  429

17.2.4  減小翻譯的代價       430

17.2.5  變的轉化爲不變的  430

17.3  一個高效的模板引擎實現思路 430

17.3.1  vm模板如何被編譯         432

17.3.2  方法調用的無反射優化  439

17.3.3  將字符輸出改爲字節輸出       442

17.4  優化的成果 443

17.4.1  將char轉成byte      443

17.4.2  無反射執行       444

17.5  其餘優化手段      445

17.6  總結      445

第18章  大瀏覽量系統的靜態化架構設計       446

18.1  淘寶大瀏覽量商品詳情繫統簡介      446

18.2  系統面臨哪些挑戰      447

18.3  淘寶前臺系統的優化歷程 449

18.4  大瀏覽量系統的靜態改造 449

18.4.1  什麼是靜態化系統  449

18.4.2  爲何要進行靜態化架構設計       450

18.4.3  如何改造動態系統  451

18.4.4  幾種靜態化方案的設計及選擇       453

18.4.5  如何解決失效問題  458

18.4.6  服務端靜態化方案的演進:CDN化      459

18.5  總結      462

參考資料         463

媒體評論

《深刻分析Java Web技術內幕(修訂版)》的內容涉及從HTTP、Servlet、模板渲染、數據層、容器到JVM 等Java Web開發的各個方面,這些問題是許令波在平常工做中常常遇到的,我想也是全部Java Web開發人員都會遇到的。《深刻分析Java Web技術內幕(修訂版)》最大的特色就是讓Java Web 開發人員對整個開發過程所涉及的技術能有一個完整的脈絡圖,從前端瀏覽器到Java 技術,再到Java 服務端技術,還介紹了實現這些技術用到的設計模式;不只詳細總結了這些技術的工做原理,並且也結合了不少實際案例來進行闡述,將複雜、難懂的技術原理經過時序圖和架構圖的方式展示出來,更加便於讀者理解。能夠說若是你掌握了本書的知識,那麼你就能夠成爲一個合格的JavaWeb開發人員。

《深刻分析Java Web技術內幕(修訂版)》文筆流暢,圖表清晰、易懂,值得推薦給Java Web 開發人員做爲進階學習的參考書。

——吳澤明(範禹),天貓產品技術部研究員

這是一本關於Java 的書,裏面講述的大量基礎知識對前端開發工程師很是有幫助。好比中文編碼章節,做者以一個實踐者的身份詳細闡述了編碼問題的方方面面。總之,這是一本很用心的書,是實踐者的思考和總結。目前在國內不多看到這類書籍,強烈推薦從事Web 開發工做的人員閱讀並實踐之。

——王保平(玉伯),開源前端類庫KISSY、SeaJS做者

做者在淘寶作了不少Java Web 方面的改造項目,在Java Web 的相關技術上有深刻的掌握,並積累了豐富的經驗。在這本書中做者不只向讀者展現了這類大改造項目所需的知識,還展現了Java Web 更爲全景的技術知識體系。本書值得Java Web 開發人員閱讀。

——林昊(畢玄),淘寶資深技術專家

從第1 次拜讀相關內容開始,就能夠感受到做者並非在簡簡單單地講述一門技術或者一個概念,他的分析和講解十分深刻,而且能夠很好地聚焦讀者的思路,尤爲是在Java Web 、Servlet 規範及字符串處理方面,都有很優秀的內容。在衆多向developerWorks投稿的國內做者中,不管是從文章的質量看,仍是從內容的選題方向看,做者的文章均可稱爲上乘之做。同時,他的多篇文章還獲得了廣大網站讀者的好評,其訪問量、評分及評論的數量均名列前茅。

——劉達,developerWorks中國Java 專區編輯、技術工程師

前言

第1版序

我第1次接觸計算機應該是在10年前,記得當時連怎麼開計算機都不會,當時感受計算機真是一個讓人着迷的東西,可是那時別說擁有一臺計算機,就算是能玩上計算機也是一件奢侈的事情了。人老是有好奇心的,而我也由於追隨着這份好奇和計算機一塊兒走過了將近10年的光陰,也是這份好奇讓我接觸了計算機,認識了計算機,到如今瞭解了計算機。可是到目前爲止我仍然有不少好奇的東西,因此我將一直求解下去。

回想我開始學習編程的時候,那是在大學期間開始構建本身的第1個網頁,而後是第1個網站之時,其中的複雜程度真是讓人不可思議。要構建一個網頁,須要學習當時的「網頁三劍客」,頁面佈局須要學習Dreamweaver,圖片處理須要學習Fireworks,動畫製做須要學習Flash。有時候爲了一個導航欄甚至通宵達旦。還有,要本身搭建一個本地服務器,要學習IIS、Apache等。當時的我居然可以一我的完成這一系列的事情,如今想一想還真是有點兒佩服本身。

如今回想一下當時本身的學習過程,真是走了不少彎路,浪費了不少時間。當時的學習就像是在一個陌生的城市找路同樣,不知道如何才能到達目的地,只能邊走邊問別人,這我的告訴你一點,那我的告訴你一點,一點一點往前走。可是雖然在往前走,走的路卻並非最近的,甚至有人指的方向是錯的。當時缺乏一個總攬全局的地圖,因此不能畫出一條最優的路。雖然走了不少彎路,可是這種不斷自學的過程仍是大大地提高了個人學習能力,這種好的自學能力也在我之後的學習工做中起到了關鍵做用。

IT行業的知識變化很快,須要不斷地學習新東西,因此學習知識的能力比掌握知識自己更重要。這也是目前大公司招聘標準中很重要的一條。記得當時個人老大在招聘我進入淘寶時,面試時就問我如何學習一門新技術。你在學習的過程當中會碰到不少難題,並會克服這些難題,不少這樣的過程積累起來就是你無形的寶貴財富。由於你遇到的問題確定也是其餘人遇到的問題,從發現問題、分析問題再到解決問題的過程遠比這個問題自己更有價值。

愛因斯坦說過:「發現問題比解決問題更重要。」對IT人員來講,發現Bug和重現Bug比解決這個Bug更有難度。這就比如一個外國人問周思來總理中國有多少廁所,總理回答說只有兩個廁所:男廁所和女廁所。可是,什麼人在什麼時間、什麼地點須要上廁所,考慮這樣的情形恐怕須要多少廁所就很難計算了。一樣,在計算機中也只有0和1兩個選擇,在計算機中的程序也一樣如此,每寫一行代碼就能增長甚至一個數量級的出錯機率。可是咱們仍是要學習如何避免出現Bug,這就要求咱們能有總理看問題的思惟,將複雜的問題簡單化,發現問題背後的本質,找到解決問題的背後的一些通用邏輯,按照這種思路來解決問題可能會讓你事半功倍。

如何讓學習知識的過程事半功倍,尤爲是咱們程序員如何作到,從我這麼多年的學習過程來講,有一些經驗能夠分享給你們,這也是我寫這本書的初衷,我真正想分享的不是我掌握的知識,更多的是我學習這個知識的過程,以及我對這些知識的一些總結和提煉。

雖然要掌握在整個Web開發中涉及的全部知識是一件很是困難的事情,尤爲是要掌握這些知識的實現原理,不只知其然還要知其因此然。因此掌握學習它們的方法相當重要。如何快速、高效地閱讀它們的源碼,有不少同窗看到我在developerWorks上發表的文章時來信問我如何閱讀各類框架的源碼,不少同窗都說不知道從哪裏入手。其實,當你掌握了一些技巧,加上你的一點耐心,這並非很難的。

本書雖然介紹了不少開源框架,可是始終都在告訴你如何才能更深刻和簡單地掌握這個框架,告訴你學習的方法,而並非告訴你這個框架有哪些類,以及怎麼使用這些零碎的知識。打個比喻,本書並非告訴你1+1=2,1+2=3,2+2=4這個結果,而後你能夠根據這個方式得出1+1+2=4,你要計算其餘數必須根據它給你的公式才能計算,而是告訴你加、減、乘、除的算法規則,而後你就能夠根據這個規則本身作運算了。

另外本書爲何要選擇介紹Web開發中這些技術的實現原理,由於只有你掌握它們的實現原理,纔可以快速地解決一些意想不到的問題。例如,當你理解了 ClassLoader的工做機制後,遇到ClassNotFoundException時,你就能快速地判斷,到底爲何會報這個錯誤,多是哪一個地方出錯致使的。

另外還有一個很重要的緣由是,若是你很想進入淘寶、騰訊、百度這樣的大型互聯網企業工做,不掌握本書講到的這些技術的實現原理,是很難經過技術面試的。由於面試官不只但願你會用這些技術,還要求你說出個因此然來,因此,掌握這些技術的實現原理能夠爲你的職業發展提供更好的機會。

本書的組織結構

本書從結構上主要分爲3部分:第1部分爲基礎知識,主要介紹在Java Web開發中涉及的一些基本知識,例如一次HTTP請求是什麼樣的,HTTP自己是如何工做的;第2部分將深刻介紹Java技術,幫助讀者瞭解Java是如何工做的,在會用的基礎上進一步理解Java;第3部分是Java服務端技術,主要介紹Web服務器的處理流程,包括Servlet容器的工做原理和Web框架是如何運轉的,也就是從Web服務器接收到請求至返回請求的這個過程當中涉及的知識,最後介紹了針對大流量狀況下的系統的一些優化技巧和實踐項目。

目標讀者

若是你是一名剛畢業的學生或者剛剛準備學習Web開發而且不知道如何入手的人,那麼這本書比較適合你;若是你已經工做1~2年,已經熟悉了Java Web開發的基本流程而且想進一步提高本身,那麼這本書更適合你。

若是你已經知道了如何學習Java Web開發技術,正準備入門進行實際開發,也就是說你是一個開發新手,那麼這本書不太適合你。可是當你知道了如何開發一個Web應用並想知道它們是如何工做時,歡迎你再回來看本書,它能幫助你進一步提升。

總的來講,本書適合如下讀者人羣。

對Web技術感受迷茫,不知道如何開始學習,對整個B/S工做機制不瞭解的同窗。

Java技術愛好者,以及想深刻學習Java技術內部實現細節的人。

有必定開發基礎,可是不瞭解Web中一些容器和框架的內部工做原理的人。

對性能優化和分佈式數據管理有興趣的大型互聯網工程師,這裏介紹了淘寶的一些實踐經驗。

開源代碼愛好者,喜歡研究開源代碼的Coder能夠從本書中找到一些分析源碼的方法。

本書不會教你如何開發Web應用程序,也不會介紹Struts、Spring、iBatis等框架如何使用。這些框架的使用參考手冊在圖書市場上有不少,本書沒有必要重複介紹。可是若是你已經掌握瞭如何使用而且不知足只會使用,想知道它們是如何工做的,想打開這些黑盒子,想之後告訴他人這些黑盒子裏到底有些什麼東西,對每種技術有強烈的好奇心,若是你是這樣的人,那麼本書值得你擁有。

本書特色

本書按照一般的學習習慣設計,爲你展現了從瀏覽器發出請求到瀏覽器最終顯示頁面的整個過程,讓你對Web開發的整個過程有個整體的理解。

本書雖然講解的都是比較深刻的技術,可是有關實踐的示例和比較恰當的比喻將幫你更好地理解。

本書將結合淘寶網中真實使用的示例應用程序來說解技術,讓讀者有更好的直觀認識。

讀者討論

因爲做者水平有限,書中不免有錯誤之處。在本書出版後的任什麼時候間,若你對本書有任何問題,你均可以經過xulingbo0201@163.com發送郵件給我,或者到http://xulingbo.net上向我提交你的建議和想法,我會對全部問題給予回覆。

致謝

感謝個人父母,在我高考失敗後仍然給我機會讓我選擇作本身想作的事,支持我選擇了本身喜歡的計算機行業,並在家庭並不富裕的狀況下給我配置了第1臺計算機,讓我有機會繼續追求本身的夢想,是大家的支持和鼓勵讓我在作本身一直喜歡作的事。

感謝個人老婆,從大學你就一直陪伴在我身邊,有你在我身邊是我不斷努力的最大動力,在本書的寫做過程當中,你完成初稿的審閱工做,同時也給了我不少鼓勵和建議。

感謝電子工業出版社的劉皎和張國霞編輯,大家嚴謹認真的工做態度讓我很是敬佩。

感謝吳澤明(範禹)老大爲本書寫序,你不只帶我進入淘寶,並且一直幫助我持續進步。感謝王保平、林昊和劉達在繁忙的工做中爲我寫推薦語。

感謝在本書寫做過程當中提出寶貴意見的同事們,他們的花名是:小凡、小邪、丹臣、哲別、景升、文通、向飛、凌棄、路奇、濟城、大仁、常彬、旭天、韓章、小賭、雁聲、索尼、鳳豪、柳擎、華黎、空望、嗷嗷、漸飛、普智、勝衣、叔度、文景、撒迦、狄龍、祝幽、單通、承澤等。

感謝developerWorks上全部向我提出問題和建議的網友們。

 

 

許令波

2012年7月

 

再版序

自《深刻分析Java Web技術內幕》一書出版以來,我收到了很多讀者的反饋,也很感謝他們指出了書中的一些錯誤和不足。時隔兩年,在電子工業出版社博文視點編輯的幫助下,《深刻分析Java Web技術內幕》有了修訂再版的機會。

這兩年來,一些技術也在發生着變化:無線技術愈來愈成熟,咱們的系統開始更多地支持無線,並衍生出系統要進行多終端化改造等問題;同時咱們也遇到了一些新的技術問題如大流量、網絡瓶頸及機房的電力短缺等,這給系統的部署和系統架構帶來新的挑戰。因此我藉此次再版的機會,將這方面的技術更新和實踐嘗試一併分享給讀者。除了修正前版的一些錯漏之處,本次修訂還主要作了如下更新。

第1章增長了CDN動態加速的內容,介紹了咱們當前最新的想法和嘗試。

第3章增長一種繁簡轉換的實現方式的內容,介紹了咱們在遇到多終端的狀況下面臨的多語言的問題,將咱們的思路和實踐分享給你們。

第10章增長了多終端Session統一的內容,也介紹了在多終端的狀況下如何解決Session統一的問題。

新增了第18章,重點介紹了咱們在近兩年遇到大流量的狀況下,如何跨越性能、網絡和一個地區的電力瓶頸等問題,並提供了一個比較完整的解決方案。

感謝劉皎和張國霞兩位編輯,感謝阿里巴巴的幾位大牛範禹、黃眉等對修訂版提供的一些有益建議,也感謝咱們技術發展部恬玉同窗的大力幫助。

 

許令波

2014.7

相關文章
相關標籤/搜索