HTTP/2服务端推送

Java 发表评论

翻译:shihuaping0918@163.com

【译者注:本文需要有一定的HTTP协议知识和浏览器解析页面过程知识】

原文 :https://blog.golang.org/h2push

前言

HTTP/2被设计为解决HTTP/1.x的许多缺陷。当代网页使用了许多资源:HTML、样式表、脚本、图片等等。在HTTP/1.x中这些资源每一个都必须明确地请求。这可能是一个很慢的过程。浏览器从获取HTML开始,然后在它解析和评估页面的时候,增量地获取更多的资源。因为服务器必须等待浏览器做每一个请求,网络经常是空闲的和未充分使用的。

为了改善延迟,HTTP/2引入了server push,它允许服务端推送资源给浏览器,在浏览器明确地请求之前。一个服务器经常知道一个页面需要很多附加资源,在它响应浏览器第一个请求的时候,可以开始推送这些资源。这允许服务端去完全充分地利用一个可能空闲的网络,改善页面加载时间。

1240

serverpush.svg.png

在协议层,HTTP/2 server push被push_promise 帧所驱动,一个PUSH_PROMISE描述了一个请求,即服务端预测浏览器将马上要发出的请求。浏览器一收到PUSH_PROMISE,它马上知道服务端将要传输这个资源。如果浏览器后续发现它需要这个资源,它会等待这个推送完成,而不是发送一个新的请求。这减少了浏览器花费在网络等待上的时间 。

net/http包中的服务端推送

go1.8引入了来自http.Server对推送响应的支持。如果运行的server是一个HTTP/2的服务,并且进来的连接是使用HTTP/2的时候,这个特性是可用的。在任意一个HTTP handler中,你可以判断http.ResponseWriter是否支持服务端推送,通过检查它是否实现了新的http.Pusher接口。

例如,如果server知道app.js将要被请求来渲染页面,如果http.Pusher可用,handler可以初始化一个push。

    http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
        if pusher, ok := w.(http.Pusher); ok {
            // Push is supported.
            if err := pusher.Push("/app.js", nil); err != nil {
                log.Printf("Failed to push: %v", err)
            }
        }
        // ...
    })

因时间关系,今天晚上先译到这……

发表评论

邮箱地址不会被公开。 必填项已用*标注

昵称 *