Java性能优化圣经!Java之父重磅推荐!
本书由曾任职于Oracle/Sun的性能优化专家编写,系统而详细地讲解了性能优化的各个方面,帮助你学习Java虚拟机的基本原理、掌握一些监控Java程序性能的工具,从而快速找到程序中的性能瓶颈,并有效改善程序的运行性能。
Java性能优化的任何问题,都可以从本书中找到答案!
第1章 策略、方法和方法论1
1.1 性能问题的现状1
1.2 性能分析的两种方法:自顶向下和自底向上4
1.2.1 自顶向下4
1.2.2 自底向上5
1.3 选择正确的平台并评估系统性能5
1.3.1 选择正确的CPU架构6
1.3.2 评估系统性能7
1.4 参考资料7
第2章 操作系统性能监控8
2.1 定义8
2.2 CPU使用率9
2.2.1 监控CPU使用率:Windows9
2.2.2 监控CPU使用率:Windows typeperf12
2.2.3 监控CPU使用率:Linux13
2.2.4 监控CPU使用率:Solaris14
2.2.5 命令行监控CPU使用率:Linux和Solaris16
2.3 CPU调度程序运行队列19
2.3.1 监控CPU调度程序运行队列:Windows19
2.3.2 监控CPU调度程序运行队列:Solaris21
2.3.3 监控CPU调度程序运行队列:Linux21
2.4 内存使用率22
2.4.1 监控内存利用率:Windows22
2.4.2 监控内存使用率:Solaris23
2.4.3 监控内存使用率:Linux24
2.4.4 监控锁竞争:Solaris25
2.4.5 监控锁竞争:Linux26
2.4.6 监控锁竞争:Windows27
2.4.7 隔离竞争锁27
2.4.8 监控抢占式上下文切换27
2.4.9 监控线程迁移28
2.5 网络I/O使用率28
2.5.1 监控网络I/O使用率:Solaris29
2.5.2 监控网络I/O使用率:Linux30
2.5.3 监控网络I/O使用率:Windows30
2.5.4 应用性能改进的考虑31
2.6 磁盘I/O使用率31
2.7 其他命令行工具34
2.8 监控CPU使用率:SPARC T系列系统35
2.9 参考资料36
第3章 JVM概览38
3.1 HotSpot VM的基本架构38
3.2 HotSpot VM运行时40
3.2.1 命令行选项40
3.2.2 VM生命周期41
3.2.3 VM类加载44
3.2.4 字节码验证46
3.2.5 类数据共享47
3.2.6 解释器48
3.2.7 异常处理49
3.2.8 同步50
3.2.9 线程管理51
3.2.10 C++堆管理53
3.2.11 Java本地接口54
3.2.12 VM致命错误处理55
3.3 HotSpot VM垃圾收集器56
3.3.1 分代垃圾收集56
3.3.2 新生代58
3.3.3 快速内存分配60
3.3.4 垃圾收集器60
3.3.5 Serial收集器61
3.3.6 Parallel收集器:吞吐量为先!62
3.3.7Mostly-Concurrent收集器:低延迟为先!62
3.3.8Garbage-First收集器:CMS替代者64
3.3.9 垃圾收集器比较64
3.3.10 应用程序对垃圾收集器的影响65
3.3.11 简单回顾收集器历史65
3.4 HotSpot VM JIT编译器65
3.4.1 类型继承关系分析67
3.4.2 编译策略67
3.4.3 逆优化68
3.4.4 Client JIT编译器概览69
3.4.5 Server JIT编译器概览69
3.4.6 静态单赋值——程序依赖图69
3.4.7 未来增强展望71
3.5 HotSpot VM自适应调优71
3.5.1 Java 1.4.2的默认值71
3.5.2 Java 5自动优化的默认值71
3.5.3 Java 6 Update 18更新后的默认优化值73
3.5.4 自适应Java堆调整74
3.5.5 超越自动优化75
3.6 参考资料75
第4章 JVM性能监控77
4.1 定义77
4.2 垃圾收集78
4.2.1 重要的垃圾收集数据78
4.2.2 垃圾收集报告78
4.2.3 垃圾收集数据的离线分析86
4.2.4 图形化工具89
4.3 JIT编译器103
4.4 类加载104
4.5 Java应用监控106
4.6 参考资料109
第5章 Java应用性能分析110
5.1 术语111
5.1.1 通用性能分析术语111
5.1.2 Oracle Solaris Studio Performance Analyzer术语112
5.1.3 NetBeans Profiler术语112
5.2 Oracle Solaris Studio Performance Analyzer112
5.2.1 支持平台113
5.2.2 下载/安装Oracle Solaris Studio Performance Analyzer114
5.2.3 使用Oracle Solaris Studio Performance Analyzer 抓取性能数据114
5.2.4 查看性能数据118
5.2.5 数据表示125
5.2.6 过滤性能数据128
5.2.7 命令行工具er_print129
5.3 NetBeans Profiler135
5.3.1 支持平台136
5.3.2 下载安装NetBeans Profiler136
5.3.3 开始方法分析会话137
5.3.4 Controls子面板143
5.3.5 Status子面板143
5.3.6 Profiling Results子面板143
5.3.7 Saved Snapshots子面板144
5.3.8 View子面板144
5.3.9 Basic Telemetry子面板144
5.3.10 查看动态结果145
5.3.11 对结果进行快照145
5.3.12 启动内存分析会话146
5.3.13 查看实时结果148
5.3.14 对结果进行快照150
5.3.15 定位内存泄漏150
5.3.16 分析堆转储151
5.4 参考资料152
第6章 Java应用性能分析技巧153
6.1 性能优化机会153
6.2 系统或内核态CPU使用154
6.3 锁竞争161
6.4 Volatile的使用171
6.5 调整数据结构的大小172
6.5.1 StringBuilder或StringBuffer大小的调整172
6.5.2 Java Collection类大小调整175
6.6 增加并行性179
6.7 过高的CPU使用率181
6.8 其他有用的分析提示182
6.9 参考资料184
第7章 JVM性能调优入门185
7.1 方法185
7.1.1 假设条件187
7.1.2 测试基础设施需求188
7.2 应用程序的系统需求188
7.2.1 可用性188
7.2.2 可管理性188
7.2.3 吞吐量189
7.2.4 延迟及响应性189
7.2.5 内存占用189
7.2.6 启动时间189
7.3 对系统需求分级190
7.4 选择JVM部署模式190
7.4.1 单JVM部署模式190
7.4.2 多JVM部署模式190
7.4.3 通用建议191
7.5 选择JVM运行模式191
7.5.1 Client模式或Server模式191
7.5.2 32位/64位 JVM192
7.5.3 垃圾收集器192
7.6 垃圾收集调优基础193
7.6.1 性能属性193
7.6.2 原则193
7.6.3 命令行选项及GC日志194
7.7 确定内存占用197
7.7.1 约束197
7.7.2 HotSpot VM堆的布局197
7.7.3 堆大小调优着眼点200
7.7.4 计算活跃数据大小201
7.7.5 初始堆空间大小配置202
7.7.6 其他考量因素203
7.8 调优延迟/响应性204
7.8.1 输入205
7.8.2 优化新生代的大小205
7.8.3 优化老年代的大小207
7.8.4 为CMS调优延迟210
7.8.5 Survivor空间介绍212
7.8.6 解析晋升阈值214
7.8.7 监控晋升阈值215
7.8.8 调整Survivor空间的容量216
7.8.9 显式的垃圾收集222
7.8.10 并发永久代垃圾收集223
7.8.11 调优CMS停顿时间224
7.8.12 下一步225
7.9 应用程序吞吐量调优225
7.9.1 CMS吞吐量调优225
7.9.2 Throughput收集器调优226
7.9.3 Survivor空间调优228
7.9.4 调优并行垃圾收集线程231
7.9.5 在NUMA系统上部署231
7.9.6 下一步232
7.10 极端示例232
7.11 其他性能命令行选项232
7.11.1 实验性(最近最大)优化232
7.11.2 逃逸分析233
7.11.3 偏向锁233
7.11.4 大页面支持234
7.12 参考资料236
第8章 Java应用的基准测试237
8.1 基准测试所面临的挑战237
8.1.1 基准测试的预热阶段238
8.1.2 垃圾收集240
8.1.3 使用Java Time接口240
8.1.4 剔除无效代码241
8.1.5 内联247
8.1.6 逆优化251
8.1.7 创建微基准测试的注意事项256
8.2 实验设计257
8.3 使用统计方法258
8.3.1 计算均值258
8.3.2 计算标准差258
8.3.3 计算置信区间259
8.3.4 使用假设测试260
8.3.5 使用统计方法的注意事项262
8.4 参考文献263
8.5 参考资料263
第9章 多层应用的基准测试264
9.1 基准测试难题264
9.2 企业级应用基准测试的考量266
9.2.1 定义被测系统266
9.2.2 制定微基准测试266
9.2.3 定义用户交互模型267
9.2.4 定义性能指标270
9.2.5 扩展基准测试273
9.2.6 用利特尔法则验证274
9.2.7 思考时间275
9.2.8 扩展性分析278
9.2.9 运行基准测试278
9.3 应用服务器监控281
9.3.1 GlassFish监控281
9.3.2 监控子系统286
9.3.3 Solaris287
9.3.4 Linux288
9.3.5 Windows288
9.3.6 外部系统的性能289
9.3.7 磁盘I/O292
9.3.8 监控和调优资源池293
9.4 企业级应用性能分析294
9.5 参考资料295
第10章 Web应用的性能调优297
10.1 Web应用的基准测试298
10.2 Web容器的组件298
10.2.1 HTTP连接器299
10.2.2 Servlet引擎300
10.3 Web容器的监控和性能调优300
10.3.1 容器的开发和生产模式300
10.3.2 安全管理器301
10.3.3 JVM调优301
10.3.4 HTTP服务和Web容器303
10.3.5 HTTP监听器303
10.4 最佳实践315
10.4.1 Servlet和JSP最佳实践315
10.4.2 内容缓存324
10.4.3 会话持久化328
10.4.4 HTTP服务器文件缓存329
10.5 参考资料333
第11章 Web Service的性能334
11.1 XML的性能334
11.1.1 XML处理的生命周期335
11.1.2 解析/解编组335
11.1.3 访问338
11.1.4 修改338
11.1.5 序列化/编组339
11.2 验证339
11.3 解析外部实体341
11.4 XML文档的局部处理343
11.5 选择合适的API346
11.6 JAX-WS参考实现栈349
11.7 Web Service基准测试350
11.8 影响Web Service性能的因素353
11.8.1 消息大小的影响353
11.8.2 不同Schema类型的性能特征355
11.8.3 终端服务器的实现358
11.8.4 处理程序的性能359
11.9 最佳性能实践361
11.9.1 二进制负载的处理361
11.9.2 处理XML文档365
11.9.3 使用MTOM发送XML文档365
11.9.4 使用Provider接口368
11.9.5 快速信息集370
11.9.6 HTTP压缩372
11.9.7 Web Service客户端的性能373
11.10 参考资料374
第12章 Java持久化及Enterprise Java Bean的性能375
12.1 EJB编程模型376
12.2 Java持久化API及其参考实现376
12.3 监控及调优EJB容器379
12.3.1 线程池380
12.3.2 Bean池和缓存382
12.3.3 EclipseLink会话缓存385
12.4 事务隔离级386
12.5 Enterprise Java Bean的最佳实践387
12.5.1 简要说明使用的EJB基准测试387
12.5.2 EJB 2.1388
12.5.3 EJB 3.0400
12.6 Java持久化最佳实践403
12.6.1 JPA查询语言中的查询403
12.6.2 查询结果缓存405
12.6.3 FetchType406
12.6.4 连接池408
12.6.5 批量更新409
12.6.6 选择正确的数据库锁策略411
12.6.7 不带事务的读取411
12.6.8 继承411
12.7 参考资料412
附录A 重要的HotSpot VM选项413
附录B 性能分析技巧示例源代码429
B.1 锁竞争实现1429
B.2 锁竞争实现2439
B.3 锁竞争实现3449
B.4 锁竞争实现4459
B.5 锁竞争实现5469
B.6 调整容量变化1481
B.7 调整容量变化2492
B.8 增加并发性的单线程实现504
B.9 增加并发性的多线程实现514
《通信电路原理学习指导书》共分8章,分别讲述了绪论、滤波器、高频放大器、非线性电路、正弦波振荡器、调制与解调、锁相环路以及
《科学、技术与社会》丛书是我国学者经过多年研究所取得的一项重大的创新性成果。它不仅系统地探索和建构了独到的STS学科体系,而
《莆田史话》内容简介:莆田地处东南沿海,历史悠久、人文鼎盛,素有“海滨邹鲁、文献名邦”之誉,也是闻名世界的“海上和平女神”
鲁然斯基等编著的《软件系统架构(使用视点和视角与利益相关者合作原书第2版)》是软件系统架构领域的开创性著作,是两位拥有数十年
《官渡杀人事件》内容简介:作品改编自马伯庸短篇小说集《三国配角演义》中的《官渡杀人事件》。建安六年,“官渡之战”主公曹操大
《太空密码》内容简介:本书是一部给孩子的天体物理学的入门读物。作者从太空生活、宇宙大爆炸到终极宇宙的命运等方面全方位解读宇
《断病如断案:中医如何看病》内容简介:本书为中医医案汇编图书,是中医专家根据多年临床诊疗经验,结合大量中医文献编写而成。全
《数据结构与算法JavaScript描述》内容简介:通过本书的学习,读者将能自如地选择最合适的数据结构与算法,并在JavaScript开发中懂
本书既系统全面又突出重点,作者从C++基础知识讲起,始终着眼于C++语言的编程实践,提供了大量实践示例和解决方案,包括如何更好
《深度学习:智能时代的核心驱动力量》内容简介:全球科技巨头纷纷拥抱深度学习,自动驾驶、AI医疗、语音识别、图像识别、智能翻译
《匿名的风景》内容简介:这是一本关于摄影思考的杂记,这本书中试图讨论三件事:一是摄影的意义与目的;二是从“糖水片”这个现象
《典藏:经典世界名画高清图集》内容简介:了解艺术史,最直观的方法就是去欣赏艺术作品。本书集结了中世纪以来艺术史上各流派的经
《C++反汇编与逆向分析技术揭秘》内容简介:本书既是一本全面而系统地讲解反汇编与逆向分析技术的安全类专著,又是一部深刻揭示C++
《王安石诗歌研究史稿(两宋时期)》内容简介:本书从研究史的角度,对王安石诗歌在宋代的流传形式及诗文集的编刻整理、王诗注本的
《犀利销售》内容简介:如何成为一名成功的销售人员?本书由浅入深,分五个层次介绍不同阶段的销售人员所应具备的能力和素质。书中
作者写作本书的灵感以及作者能提供的大量翔实的信息都直接来源于作者在UMTS论坛担任主席内5年的经历。在它最为活跃的阶段,这个国
《梁启超修身三书:德育鉴》内容简介:二十世纪初,梁启超(任公)先后编纂了三种关于传统的修身方面的书。此三书既是梁启超本人用
《社交电商运营全攻略》内容简介:随着新零售的大潮在国内兴起,有赞学院决定将自身的经验分享给大家,《社交电商运营全攻略》是由
Pro/ENGGINEER野火版4.0基础教程与上机指导 (孙传祝) 本书特色 《Pro/ENGINEER野火版 4.0基础教程与上机指导》涵盖Pro/ENGI...
WebRTC是一个支持网络浏览器进行实时语音对话或视频对话的软件架构。《LearningWebRTC中文版》使用形象的案例介绍,逐步深入地阐