《Web性能权威指南》

基本信息

原书名:High performance browser networking

原出版社: O'Reilly Media

作者: (加)Ilya Grigorik

译者: 李松峰

丛书名: 图灵程序设计丛书

出版社:人民邮电出版社

ISBN:9787115349101

上架时间:2014-4-2

出版日期:2014 年5月

开本:16开

页码:317

版次:1-1

所属分类:计算机 > 计算机网络 > Web Server > 综合

更多关于》》》《Web性能权威指南》

编辑推荐 

怎么才能让Web应用速度快、效率高?本书为所有关心这个问题的人提供了必须知道的网络知识,既包括影响性能的最基本因素,也包括那些能让我们创造更强大Web应用的重要技术革新,比如HTTP 2.0、XHR的改进、服务器发送事件(SSE)、WebSocket和WebRTC等。

内容简介

书籍

计算机书籍

  《web性能权威指南》是谷歌公司高性能团队核心成员的权威之作,堪称实战经验与规范解读完美结合的产物。本书目标是涵盖web 开发者技术体系中应该掌握的所有网络及性能优化知识。全书以性能优化为主线,从tcp、udp 和tls 协议讲起,解释了如何针对这几种协议和基础设施来优化应用。然后深入探讨了无线和移动网络的工作机制。最后,揭示了http 协议的底层细节,同时详细介绍了http 2.0、 xhr、sse、websocket、webrtc 和datachannel 等现代浏览器新增的具有革命性的新能力。

  《web性能权威指南》适合所有web 应用及站点开发人员阅读,包括但不限于前端、后端、运维、大数据分析、ui/ux、存储、视频、实时消息,以及性能工程师。

媒体评论

  “所有关注Web性能的人都应该看这本书,它是这个领域公认的权威参考指南。”

  ——Mark Nottingham

  IETF下一代HTTP工作组(HTTPbis Working Group)主席

  所有Web开发相关人员,都应该看这本书

  本书恰如其分地总结了性能问题的症结所在,以及HTTP和HTTPS优化技术。关于未来HTTP 2.0的内容也很多,很全面。

  ——Peter M. Goldstein

  绝对好书

  干这行的所有人必读。作者的研究工作叹为观止,信息全面翔实,而且全书结构紧凑,条理明晰。希望这本书能不断升级。

  ——JonoReview

  不看这本书不叫全栈工程师

  这本书涵盖了Web开发日常所用的协议、网络和API。作者断定延迟是Web性能的罪魁祸首,然后从客户端到服务器端,将TCP、UDP和TLS的工作原理娓娓道来,接着是各种无线网络连接技术,最后深入剖析了HTTP、XHR、SSE、WebSocket和WebRTC。作者以数据支撑自己的观点,整本书涵盖了Web网络开发涉及的方方面面。不管你是工作在前端还是后端,这本书都能为你优化应用提供最基本的常识。

  看完这本书,我真是受益匪浅,但我还想再看一遍,因为我担心遗漏了什么。这本书我高度推荐,在这个领域里,我还没发现有第二本类似的书。

  —— R. Friesel Jr. "found_drama"

  内容全面、解读精准

  我可以发誓,不管是谁,能把这本书看下来,看明白,你就是Web性能优化方面的无所不知的大牛了。

  我在微软IE团队当了8年网络程序管理员,仍然从这本书里学到了很多东西。而且,这本书跟我看过的其他书不一样,这本书中的每个细节都准确无误,的的确确是行业专家的手笔,跟那些只为挣钱的书有天壤之别。

  ——Eric Lawrence

  时代的杰作

  这本权威指南揭开了浏览器神秘的面纱。不光详细讲解了网络协议,同时还给出了实用的建议,而且深入探讨了令人兴奋的新技术。

  ——Peter Lubbers "Peter Lubbers

目录

《web性能权威指南》

steve souders 推荐序  xiii

前言  xv

第一部分 网络技术概览

第1章 延迟与带宽  3

1.1  速度是关键  3

1.2  延迟的构成  4

1.3  光速与传播延迟  6

1.4  延迟的最后一公里  7

1.5  网络核心的带宽  8

1.6  网络边缘的带宽  9

1.7  目标:高带宽和低延迟  10

第2章 tcp 的构成  13

2.1  三次握手  14

2.2  拥塞预防及控制  16

2.2.1  流量控制  16

2.2.2  慢启动  18

2.2.3  拥塞预防  24

2.3  带宽延迟积  25

2.4  队首阻塞  27

2.5  针对tcp 的优化建议  28

2.5.1  服务器配置调优  29

2.5.2  应用程序行为调优  30

2.5.3  性能检查清单  30

第3章 udp 的构成  31

3.1  无协议服务  32

3.2  udp 与网络地址转换器  34

3.2.1  连接状态超时  35

3.2.2  nat 穿透  36

3.2.3  stun、turn 与ice  37

3.3  针对udp 的优化建议  39

第4章 传输层安全(tls)  41

4.1  加密、身份验证与完整性  42

4.2  tls 握手  44

4.2.1  应用层协议协商(alpn)  46

4.2.2  服务器名称指示(sni)  47

4.3  tls 会话恢复  48

4.3.1  会话标识符  48

4.3.2  会话记录单  49

4.4  信任链与证书颁发机构  50

4.5  证书撤销  52

4.5.1  证书撤销名单(crl)  53

4.5.2  在线证书状态协议(ocsp)  54

4.6  tls 记录协议  54

4.7  针对tls 的优化建议  55

4.7.1  计算成本  55

4.7.2  尽早完成(握手)  56

4.7.3  会话缓存与无状态恢复  58

4.7.4  tls 记录大小  59

4.7.5  tls 压缩  60

4.7.6  证书链的长度  61

4.7.7  ocsp 封套  62

4.7.8  http 严格传输安全(hsts)  62

4.8  性能检查清单  63

4.9  测试与验证  64

第二部分 无线网络性能

第5章 无线网络概览  69

5.1  无所不在的连接  69

5.2  无线网络的类型  70

5.3  无线网络的性能基础  71

5.3.1  带宽  71

5.3.2  信号强度  74

5.3.3  调制  75

5.4  测量现实中的无线性能  76

第6章 wi-fi  79

6.1  从以太网到无线局域网  79

6.2  wi-fi 标准及功能  81

6.3  测量和优化wi-fi 性能  81

6.4  针对wi-fi 的优化建议  84

6.4.1  利用不计流量的带宽  84

6.4.2  适应可变带宽  85

6.4.3  适应可变的延迟时间  86

第7章 移动网络  87

7.1  g 字号移动网络简介  87

7.1.1  最早提供数据服务的2g  88

7.1.2  3gpp 与3gpp2  89

7.1.3  3g 技术的演进  91

7.1.4  imt-advanced 的4g 要求  93

7.1.5  长期演进(lte)  94

7.1.6  hspa+ 推进世界范围内的4g 普及  95

7.1.7  为多代并存的未来规划  96

7.2  设备特性及能力  97

7.3  无线电资源控制器(rrc)  99

7.3.1  3g、4g 和wi-fi 对电源的要求  101

7.3.2  lte rrc 状态机  102

7.3.3  hspa 与hspa+(umts)rrc 状态机  104

7.3.4  ev-do(cdma) rrc 状态机  106

7.3.5  低效率的周期性传输  107

7.4  端到端的运营商架构  108

7.4.1  无线接入网络(ran)  108

7.4.2  核心网络  110

7.4.3  回程容量与延迟  112

7.5  移动网络中的分组流  113

7.5.1  初始化请求  113

7.5.2  入站数据流  116

7.6  异质网络(hetnet)  117

7.7  真实的3g、4g 和wi-fi 性能  119

第8章 移动网络的优化建议  121

8.1  节约用电  122

8.2  消除周期性及无效的数据传输  124

8.3  预测网络延迟上限  126

8.3.1  考虑rrc 状态切换  127

8.3.2  解耦用户交互与网络通信  128

8.4  面对多网络接口并存的现实  128

8.5  爆发传输数据并转为空闲  130

8.6  把负载转移到wi-fi 网络  131

8.7  遵从协议和应用最佳实践  131

第三部分 http

第9章 http 简史  135

9.1  http 0.9:只有一行的协议  135

9.2  http 1.0:迅速发展及参考性rfc  136

9.3  http 1.1:互联网标准  138

9.4  http 2.0:改进传输性能  141

第10章 web 性能要点  143

10.1  超文本、网页和web 应用  144

10.2  剖析现代web 应用  146

10.2.1  速度、性能与用户期望  147

10.2.2  分析资源瀑布  148

10.3  性能来源:计算、渲染和网络访问  151

10.3.1  更多带宽其实不(太)重要  152

10.3.2  延迟是性能瓶颈  152

10.4  人造和真实用户性能度量  154

10.5  针对浏览器的优化建议  157

第11章 http 1.x  161

11.1  持久连接的优点  163

11.2  http 管道  165

11.3  使用多个tcp 连接  169

11.4  域名分区  171

11.5  度量和控制协议开销  173

11.6  连接与拼合  174

11.7  嵌入资源  177

第12章 http 2.0  179

12.1  历史及其与spdy 的渊源  180

12.2  走向http 2.0  181

12.3  设计和技术目标  182

12.3.1  二进制分帧层  183

12.3.2  流、消息和帧  184

12.3.3  多向请求与响应  185

12.3.4  请求优先级  186

12.3.5  每个来源一个连接  188

12.3.6  流量控制  189

12.3.7  服务器推送  190

12.3.8  首部压缩  192

12.3.9  有效的http 2.0 升级与发现  194

12.4  二进制分帧简介  196

12.4.1  发起新流  197

12.4.2  发送应用数据  198

12.4.3  http 2.0 帧数据流分析  199

第13章 优化应用的交付  201

13.1  经典的性能优化最佳实践  203

13.1.1  在客户端缓存资源  204

13.1.2  压缩传输的数据  205

13.1.3  消除不必要的请求字节  206

13.1.4  并行处理请求和响应  207

13.2  针对http 1.x 的优化建议  208

13.3  针对http 2.0 的优化建议  209

13.3.1  去掉对1.x 的优化  209

13.3.2  双协议应用策略  210

13.3.3  1.x 与2.0 的相互转换  212

13.3.4  评估服务器质量与性能  213

13.3.5  2.0 与tls  214

13.3.6  负载均衡器、代理及应用服务器  215

第四部分 浏览器api 与协议

第14章 浏览器网络概述  219

14.1  连接管理与优化  220

14.2  网络安全与沙箱  222

14.3  资源与客户端状态缓存  222

14.4  应用api 与协议  223

第15章 xmlhttprequest  225

15.1  xhr 简史  226

15.2  跨源资源共享(cors)  227

15.3  通过xhr 下载数据  230

15.4  通过xhr 上传数据  231

15.5  监控下载和上传进度  233

15.6  通过xhr 实现流式数据传输  234

15.7  实时通知与交付  236

15.7.1  通过xhr 实现轮询  237

15.7.2  通过xhr 实现长轮询  238

15.8  xhr 使用场景及性能  240

第16章 服务器发送事件  243

16.1  eventsource api  243

16.2  event stream 协议  245

16.3  sse 使用场景及性能  248

第17章 websocket  251

17.1  websocket api  252

17.1.1  ws 与wss  253

17.1.2  接收文本和二进制数据  253

17.1.3  发送文本和二进制数据  255

17.1.4  子协议协商  256

17.2  websocket 协议  257

17.2.1  二进制分帧层  258

17.2.2  协议扩展  260

17.2.3  http 升级协商  261

17.3  websocket 使用场景及性能  264

17.3.1  请求和响应流  264

17.3.2  消息开销  265

17.3.3  数据效率及压缩  266

17.3.4  自定义应用协议  266

17.3.5  部署websocket 基础设施  267

17.4  性能检查表  269

第18章 webrtc  271

18.1  标准和webrtc 的发展  272

18.2  音频和视频引擎  272

18.3  实时网络传输  276

18.4  建立端到端的连接  280

18.4.1  发信号和协商会话  280

18.4.2  会话描述协议(sdp)  282

18.4.3  交互连接建立(ice)  285

18.4.4  增量提供(trickle ice)  288

18.4.5  跟踪ice 收集和连接状态  289

18.4.6  完整的示例  291

18.5  交付媒体和应用数据  295

18.5.1  通过dtls 实现安全通信  296

18.5.2  通过srtp 和srtcp 交付媒体  298

18.5.3  通过sctp 交付应用数据  301

18.6  datachannel  305

18.6.1  设置与协商  307

18.6.2  配置消息次序和可靠性  309

18.6.3  部分可靠交付与消息大小  311

18.7  webrtc 使用场景及性能  312

18.7.1  音频、视频和数据流  312

18.7.2  多方通信架构  313

18.7.3  基础设施及容量规划  314

18.7.4  数据效率及压缩  315

18.8  性能检查表  316

关于封面  318

本图书信息来源:互动出版网

《Web性能权威指南》的更多相关文章

  1. 简单物联网:外网访问内网路由器下树莓派Flask服务器

    最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...

  2. 利用ssh反向代理以及autossh实现从外网连接内网服务器

    前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...

  3. 外网访问内网Docker容器

    外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...

  4. 外网访问内网SpringBoot

    外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...

  5. 外网访问内网Elasticsearch WEB

    外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...

  6. 怎样从外网访问内网Rails

    外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...

  7. 怎样从外网访问内网Memcached数据库

    外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...

  8. 怎样从外网访问内网CouchDB数据库

    外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...

  9. 怎样从外网访问内网DB2数据库

    外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...

  10. 怎样从外网访问内网OpenLDAP数据库

    外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...

随机推荐

  1. T-SQL语句3

    一.删除表 1.drop table语句 drop table database_name,schema_name,table_name 2.删除数据表 drop table dbo.t_delete ...

  2. Mysql报Cannot load from mysql.proc. The table is probably corrupted

    1548-Cannot load from mysql.proc. The table is probably corrupted http://bugs.mysql.com/bug.php?id=5 ...

  3. STM32 串口通信使用奇偶校验

    STM32串口通信如果使用奇偶校验,需要设置数据位长度为9bit USART_InitStructure.USART_BaudRate = 9600; USART_InitStructure.USAR ...

  4. 7-12 The Rotation Game IDA*

    状态搜索题目  一开始打算用bfs  但是图给的不是矩形图  有点难以下手 参考了 lrj    将图上所有的点进行标号  直接一个一维数组就解决了图的问题  并且明确了每个点的标号  处理起来十分方 ...

  5. 028 -bash-4.1$ 出现故障的原理及解决办法?

    最近在搭建分布式的时候,出现了这个问题,很不爽.下面是我的解决方式. 1.在用户下删除bash rm -rf /home/beifeng/.bash* 2.拷贝 cp /etc/skel/.bash* ...

  6. 使用SOCKET获取网页的内容

    使用fsockopen()函数来实现获取页面信息,完整代码如下 //设置字符集(由于要抓取的网易网站字符集编码是gbk编码) header("content-type:text/html;c ...

  7. phpinfo常见配置信息

    在开发过程中,经常碰到比如加载的是哪个配置文件.上传文件大小受限.PHP错误日志文件位置等问题需要快速查找出来并解决,因此总结记录出下面的相关配置. phpinfo - 输出关于 PHP 配置的信息 ...

  8. 多线程学习笔记七之信号量Semaphore

    目录 简介 数据结构 示例 实现分析 构造方法 信号量的获取(公平方式) 信号量的释放(公平方式) nonfairTryAcquireShared(int acquires) 总结 简介   Sema ...

  9. [CF580E]Kefa and Watch

    题目大意: 维护一个由'0'~'9'构成的字符串,支持以下两种操作: 1.将指定区间内的所有字符修改为同一指定字符. 2.询问$x$是否为指定区间内的循环节. 思路: 建立一棵线段树,维护每个子串的哈 ...

  10. ORA-01591 锁定已被有问题的分配事务处理--解决方法(转)

    转载自love wife & love life —Roger 的Oracle技术博客 本文链接地址: ORA-01591: lock held by in-doubt distributed ...