为什么要进行请求和响应的优化?
核心目的:更快的获取到内容。
核心思路
- 更好的连接传输效率。
- 更少的请求数量。
- 更小的资源大小。
- 合适的缓存策略。
最佳实践
- 减少DNS查找:每次主机名的解析都需要一次网络往返,从而增加了请求的延迟时间,同时还会阻塞后续的请求。
- 重用TCP连接:尽可能的使用持久连接,以消除因TCP握手和慢启动导致的延迟。
- 减少HTTP重定向:HTTP重定向需要额外的DNS查询,TCP握手等非常耗时,最佳的重定向次数为0。
- 压缩传输的资源:比如Gzip、图片缓存。
- 使用缓存:比如HTTP缓存、CDN缓存、Service Worker缓存。
- 使用CDN内容分发网络:把数据放在里用户地理位置更近的地方,可以明显减少每次TCP连接的网络延迟,增大吞吐量。
- 删除没有必要请求的资源。
- 在客户端缓存资源:缓存必要的应用资源,避免每次都重复请求相同的内容,例如多图片下载可以考虑使用缓存。
- 内容在传输前先压缩:传输数据之前应该先压缩应用资源,把要传输的字节减少到最小,在压缩的时候确保对每种不同的资源采用最好的压缩手段。
- 消除不必要的请求开销:减少请求的HTTP首部数据(比如HTTP Cooki)
- 并行处理请求和响应:请求和响应的排队都会导致延迟,可以尝试并行的处理请求和响应(利用多个HTTP1.1连接实现并行下载,在可能的情况下使用HTTP管道计数)。
- 针对协议版本采取优化措施:例如升级到HTTP2.0。
- 根据需要采用服务端渲染方式:这种方式可以解决SPA应用首屏渲染慢的问题。
- 采用预渲染的方式加速静态页面:页面渲染的极致性能,比较适合静态页面。