Why request and response optimization?
Core purpose: Get content faster.
The core idea
- Better connection transmission efficiency.
- Fewer requests.
- Smaller resource sizes.
- Appropriate caching strategy.
Best practices
- Reduced DNS lookups: Each resolution of a host name requires a network round trip, increasing latency for requests and blocking subsequent requests.
- Reuse TCP connections: Use persistent connections whenever possible to eliminate delays caused by TCP handshakes and slow starts.
- Reduce HTTP redirects: HTTP redirects require additional DNS queries, TCP handshakes, etc., are very time consuming, and the optimal number of redirects is 0.
- Compress transmitted resources: such as Gzip, image cache.
- Use caches: such as HTTP cache, CDN cache, Service Worker cache.
- Using CDN content distribution network: placing data closer to the geographical location of users in the network can significantly reduce the network latency of each TCP connection and increase throughput.
- Delete resources that do not need to be requested.
- Caching resources on the client side: Cache necessary application resources to avoid repeating requests for the same content each time. For example, consider using caching for multiple image downloads.
- Compress content before transfer: Compress application resources before transferring data, minimizing the number of bytes to be transferred, and ensuring that the best compression method is used for each different resource.
- Eliminate unnecessary request overhead: Reduce HTTP header data for requests (such as HTTP Cooki)
- Parallel processing of requests and responses: Queuing of both requests and responses causes delays, and you can try to process requests and responses in parallel (parallel downloads with multiple HTTP1.1 connections, using HTTP pipeline counts where possible).
- Optimize for protocol version: for example, upgrade to HTTP2.0.
- Use server-side rendering as required: this method can solve the problem of slow first screen rendering of SPA applications.
- Use pre-render to speed up static pages: the ultimate performance of page rendering, more suitable for static pages.