第1章 深刻Web请求过程 1
1.1 B/S网络架构概述 2
基于统一的应用层协议HTTP来交互数据。算法

1.2 如何发起一个请求 4
HTTP链接本质是创建Socket链接。请求实现方式:工具包如HttpClient、curl+URL、浏览器输入URL回车。数据库
1.3 HTTP协议解析 6
Headers查看步骤:F12->Network->F5->URL->Headers。设计模式



1.3.1 查看HTTP信息的工具 8
Firefox--Firebug、F12浏览器
1.3.2 浏览器缓存机制 9
Ctrl+F5组合键刷新,会不使用缓存。Request Headers会多Pragma: no-cache,Cache-Control: private变为Cache-Control: no-cache缓存
1.4 DNS域名解析 12
域名解析成IP地址安全
1.4.1 DNS域名解析过程 12

1.浏览器检查缓存中有没有这个域名解析过的IP地址。服务器
2.操做系统域名解析,Windows在C:\Windows\System32\drivers\etc\hosts,Linux在/etc/hosts,能够指定域名对应IP。(被黑客修改致使域名劫持)网络
3.发送给本地区的域名服务器(Loal DNS),一般是互联网供应商,如联通、电信,约80%的域名解析到这里已经完成。数据结构
4.域名服务器(Root Server)请求解析架构
5.Root Server返回给LDNS一个所查询域的主域名服务器(gTLD Server)地址。gTLD 是国际顶级域名服务器,如.com、.cn等
6.LDNS再向gTLD发送请求
7.gTLD返回对应的Name Server域名服务器的地址,Name Server是你在某个域名服务提供商注册的域名服务器。
8.Name Server查询域名和IP映射关系表,连同TTL(Time To Live)返回给DNS Server
9.LDNS缓存域名和IP对应关系和缓存的时间
10.结果返回给用户,用户根据TTL值缓存在本地系统缓存中。
1.4.2 跟踪域名解析过程 15
Linux、Windows下均可以使用nslookup命令查询域名解析结果;Linux还可使用dig命令查询DNS解析过程
1.4.3 清除缓存的域名 18
Windows:ipconfig /flushdns
Linux:sudo /etc/init.d/nscd restart
1.4.4 几种域名解析方式 19
A记录:Address,指定域名对应的IP地址
MX记录:Mail Exchange,能够将某个域名下的邮件服务指向到本身的Mail Server
CNAME记录:Canonical Name,别名解析,为一个域名设置一个或多个别名
NS记录:为某个域名指定DNS解析服务器
TXT记录:为主机或域名设置说明
1.5 CDN工做机制 20
CDN( Content Delivery Network):内容分布网络,在现有的 Internet中增长一层新的网络架构,将网站的内容发布到最接近用户的网络“边缘”,使用户能够就近取得所需的内容,提升用户访问网站的响应速度。以缓存网站中的静态数据为主
1.5.1 CDN架构 20

1.5.2 负载均衡 21

1.5.3 CDN动态加速 21
在CDN的DNS解析中经过动态的链路探测来寻找回源最好的一条路径,而后经过DNS的调度将全部请求调度到选定的这条路径上回源,从而加速用户访问的效率。

1.6 总结 24
第2章 深刻分析Java I/O的工做机制 25
2.1 Java的I/O类库的基本架构 25
基于字节操做的IO接口:InputStream 和 OutputStream(传输数据的数据格式)
基于字符操做的IO接口:Writer 和 Reader(传输数据的数据格式)
基于磁盘操做的IO接口:File(传输数据的方式)
基于网络操做的IO接口:Socket(传输数据的方式)
2.1.1 基于字节的I/O操做接口 26

2.1.2 基于字符的I/O操做接口 27


2.1.3 字节与字符的转化接口 28


2.2 磁盘I/O工做机制 29
2.2.1 几种访问文件的方式 29
2.2.2 Java访问磁盘文件 33
2.2.3 Java序列化技术 34
2.3 网络I/O工做机制 36
2.3.1 TCP状态转化 37
2.3.2 影响网络传输的因素 39
2.3.3 Java Socket的工做机制 39
2.3.4 创建通讯链路 40
2.3.5 数据传输 41
2.4 NIO的工做方式 41
2.4.1 BIO带来的挑战 41
2.4.2 NIO的工做机制 42
2.4.3 Buffer的工做方式 45
2.4.4 NIO的数据访问方式 47
2.5 I/O调优 49
2.5.1 磁盘I/O优化 49
2.5.2 TCP网络参数调优 50
2.5.3 网络I/O优化 52
2.6 设计模式解析之适配器模式 56
2.6.1 适配器模式的结构 56
2.6.2 Java I/O中的适配器模式 57
2.7 设计模式解析之装饰器模式 57
2.7.1 装饰器模式的结构 58
2.7.2 Java I/O中的装饰器模式 58
2.8 适配器模式与装饰器模式的区别 59
2.9 总结 59
第3章 深刻分析Java Web中的中文编码问题 60
3.1 几种常见的编码格式 60
3.1.1 为何要编码 60
3.1.2 如何“翻译” 61
3.2 Java中须要编码的场景 63
3.2.1 I/O操做中存在的编码 63
3.2.2 内存操做中的编码 65
3.3 Java中如何编解码 66
3.3.1 按照ISO-8859-1编码 68
3.3.2 按照GB2312编码 69
3.3.3 按照GBK编码 70
3.3.4 按照UTF-16编码 70
3.3.5 按照UTF-8编码 71
3.3.6 UTF-8编码代码片断 71
3.3.7 几种编码格式的比较 73
3.4 Java Web中涉及的编解码 73
3.4.1 URL的编解码 75
3.4.2 HTTP Header的编解码 78
3.4.3 POST表单的编解码 78
3.4.4 HTTP BODY的编解码 79
3.5 JS中的编码问题 80
3.5.1 外部引入JS文件 80
3.5.2 JS的URL编码 81
3.5.3 其余须要编码的地方 83
3.6 常见问题分析 83
3.6.1 中文变成了看不懂的字符 83
3.6.2 一个汉字变成一个问号 84
3.6.3 一个汉字变成两个问号 84
3.6.4 一种不正常的正确编码 85
3.7 总结 86
第4章 Javac编译原理 87
4.1 Javac是什么 88
4.2 Javac编译器的基本结构 88
4.3 Javac工做原理分析 90
4.3.1 词法分析器 91
4.3.2 语法分析器 98
4.3.3 语义分析器 103
4.3.4 代码生成器 113
4.4 设计模式解析之访问者模式 116
4.4.1 访问者模式的结构 117
4.4.2 Javac中访问者模式的实现 118
4.5 总结 119
第5章 深刻class文件结构 120
5.1 JVM指令集简介 120
5.1.1 类相关的指令 122
5.1.2 方法的定义 123
5.1.3 属性的定义 124
5.1.4 其余指令集 125
5.2 class文件头的表示形式 133
5.3 常量池 137
5.3.1 UTF8常量类型 140
5.3.2 Fieldref、Methodref常量类型 141
5.3.3 Class常量类型 141
5.3.4 NameAndType常量类型 142
5.4 类信息 142
5.5 Fields和Methods定义 143
5.6 类属性描述 147
5.7 Javap生成的class文件结构 148
5.7.1 LineNumberTable 150
5.7.2 LocalVariableTable 151
5.8 总结 153
第6章 深刻分析ClassLoader 工做机制 154
6.1 ClassLoader类结构分析 155
6.2 ClassLoader的等级加载机制 156
6.3 如何加载class文件 159
6.3.1 加载字节码到内存 159
6.3.2 验证与解析 161
6.3.3 初始化Class对象 161
6.4 常见加载类错误分析 161
6.4.1 ClassNotFoundException 161
6.4.2 NoClassDefFoundError 162
6.4.3 UnsatisfiedLinkError 163
6.4.4 ClassCastException 164
6.4.5 ExceptionInInitializerError 165
6.5 经常使用的ClassLoader分析 166
6.6 如何实现本身的ClassLoader 170
6.6.1 加载自定义路径下的class文件 170
6.6.2 加载自定义格式的class文件 172
6.7 实现类的热部署 174
6.8 Java应不该该动态加载类 176
6.9 总结 177
第7章 JVM体系结构与工做方式 178
7.1 JVM体系结构 178
7.1.1 何谓JVM 178
7.1.2 JVM体系结构详解 181
7.2 JVM工做机制 183
7.2.1 机器如何执行代码 183
7.2.2 JVM为什么选择基于栈的架构 184
7.2.3 执行引擎的架构设计 185
7.2.4 执行引擎的执行过程 186
7.2.5 JVM方法调用栈 191
7.3 总结 195
第8章 JVM内存管理 196
8.1 物理内存与虚拟内存 197
8.2 内核空间与用户空间 198
8.3 Java中哪些组件须要使用内存 199
8.3.1 Java堆 199
8.3.2 线程 199
8.3.3 类和类加载器 200
8.3.4 NIO 200
8.3.5 JNI 201
8.4 JVM内存结构 201
8.4.1 PC寄存器 202
8.4.2 Java栈 202
8.4.3 堆 203
8.4.4 方法区 203
8.4.5 运行时常量池 204
8.4.6 本地方法栈 204
8.5 JVM内存分配策略 204
8.5.1 一般的内存分配策略 205
8.5.2 Java中内存分配详解 205
8.6 JVM内存回收策略 210
8.6.1 静态内存分配和回收 210
8.6.2 动态内存分配和回收 211
8.6.3 如何检测垃圾 211
8.6.4 基于分代的垃圾收集算法 213
8.7 内存问题分析 222
8.7.1 GC日志分析 222
8.7.2 堆快照文件分析 225
8.7.3 JVM Crash日志分析 225
8.8 实例1 231
8.9 实例2 233
8.10 实例3 235
8.11 总结 240
第9章 Servlet工做原理解析 241
9.1 从Servlet容器提及 241
9.1.1 Servlet容器的启动过程 242
9.1.2 Web应用的初始化工做 245
9.2 建立Servlet实例 247
9.2.1 建立Servlet对象 248
9.2.2 初始化Servlet 248
9.3 Servlet体系结构 250
9.4 Servlet如何工做 253
9.5 Servlet中的Listener 255
9.6 Filter如何工做 257
9.7 Servlet中的url-pattern 259
9.8 总结 260
第10章 深刻理解Session与Cookie 261
10.1 理解Cookie 262
10.1.1 Cookie属性项 262
10.1.2 Cookie如何工做 263
10.1.3 使用Cookie的限制 266
10.2 理解Session 267
10.2.1 Session与Cookie 267
10.2.2 Session如何工做 268
10.3 Cookie安全问题 271
10.4 分布式Session框架 272
10.4.1 存在哪些问题 272
10.4.2 能够解决哪些问题 273
10.4.3 整体实现思路 273
10.5 Cookie压缩 278
10.6 表单重复提交问题 280
10.7 总结 281
第11章 Tomcat的系统架构与 设计模式 282
11.1 Tomcat整体设计 282
11.1.1 Tomcat整体结构 283
11.1.2 Connector组件 289
11.1.3 Servlet容器Container 294
11.1.4 Tomcat中的其余组件 305
11.2 Tomcat中的设计模式 305
11.2.1 门面设计模式 305
11.2.2 观察者设计模式 307
11.2.3 命令设计模式 309
11.2.4 责任链设计模式 310
11.3 总结 312
第12章 Jetty的工做原理解析 313
12.1 Jetty的基本架构 313
12.1.1 Jetty的基本架构简介 313
12.1.2 Handler的体系结构 315
12.2 Jetty的启动过程 316
12.3 接受请求 317
12.3.1 基于HTTP协议工做 317
12.3.2 基于AJP工做 319
12.3.3 基于NIO方式工做 322
12.4 处理请求 323
12.5 与Jboss集成 326
12.6 与Tomcat的比较 327
12.6.1 架构比较 327
12.6.2 性能比较 328
12.6.3 特性比较 328
12.7 总结 329
第13章 Spring框架的设计理念与 设计模式分析 330
13.1 Spring的骨骼架构 330
13.1.1 Spring的设计理念 331
13.1.2 核心组件如何协同工做 332
13.2 核心组件详解 333
13.2.1 Bean组件 333
13.2.2 Context组件 335
13.2.3 Core组件 336
13.2.4 Ioc容器如何工做 338
13.3 Spring中AOP特性详解 348
13.3.1 动态代理的实现原理 348
13.3.2 Spring AOP如何实现 351
13.4 设计模式解析之代理模式 354
13.4.1 代理模式原理 354
13.4.2 Spring中代理模式的实现 354
13.5 设计模式解析之策略模式 357
13.5.1 策略模式原理 357
13.5.2 Spring中策略模式的实现 358
13.6 总结 358
第14章 Spring MVC工做机制与 设计模式 360
14.1 Spring MVC的整体设计 360
14.2 Control设计 365
14.2.1 HandlerMapping初始化 366
14.2.2 HandlerAdapter初始化 368
14.2.3 Control的调用逻辑 369
14.3 Model设计 370
14.4 View设计 371
14.5 框架设计的思考 373
14.5.1 为何须要框架 373
14.5.2 须要什么样的框架 373
14.5.3 框架设计的原则 374
14.5.4 “指航灯” 374
14.5.5 最基本的原则 374
14.6 设计模式解析之模板模式 375
14.6.1 模板模式的结构 375
14.6.2 Spring MVC中的模板模式示例 376
14.7 总结 377
第15章 深刻分析Ibatis框架之系统 架构与映射原理 378
15.1 Ibatis框架主要的类层次结构 378
15.2 Ibatis框架的设计策略 379
15.3 Ibatis框架的运行原理 381
15.4 示例 383
15.5 Ibatis对SQL语句的解析 385
15.6 数据库字段映射到Java对象 386
15.7 示例运行的结果 388
15.8 设计模式解析之简单工厂模式 388
15.8.1 简单工厂模式的实现原理 388
15.8.2 Ibatis中的简单工厂模式示例 389
15.9 设计模式解析之工厂模式 390
15.9.1 工厂模式的实现原理 390
15.9.2 Ibatis中的工厂模式示例 391
15.10 总结 392
第16章 Velocity工做原理解析 394
16.1 Velocity整体架构 395
16.2 JJTree渲染过程解析 398
16.2.1 #set语法 402
16.2.2 Velocity的方法调用 403
16.2.3 #if、#elseif和#else语法 406
16.2.4 #foreach语法 407
16.2.5 #parse语法 409
16.3 事件处理机制 410
16.4 经常使用优化技巧 413
16.4.1 减小树的总节点数量 413
16.4.2 减小渲染耗时的节点数量 413
16.5 与JSP比较 414
16.5.1 JSP渲染机制 414
16.5.2 Velocity与JSP 420
16.6 设计模式解析之合成模式 420
16.6.1 合成模式的结构 420
16.6.2 Velocity中合成模式的实现 421
16.7 设计模式解析之解释器模式 422
16.7.1 解释器模式的结构 422
16.7.2 Velocity中解释器模式的实现 423
16.8 总结 423
第17章 Velocity优化实践 424
17.1 现实存在的问题 424
17.2 优化的理论基础 425
17.2.1 程序语言的三角形结构 425
17.2.2 数据结构减小抽象化 426
17.2.3 简单的程序复杂化 426
17.2.4 减小翻译的代价 427
17.2.5 变的转化为不变 427
17.3 一个高效的模板引擎的实现思路 427
17.3.1 vm模板如何被编译 429
17.3.2 方法调用的无反射优化 436
17.3.3 字符输出改为字节输出 439
17.4 优化的成果 440
17.4.1 char转成byte 440
17.4.2 无反射执行 441
17.5 其余优化手段 442
17.6 总结 442