登录
首页 >  Golang >  Go问答

如何使用 Server.TLSNextProto 禁用 HTTP/2

来源:stackoverflow

时间:2024-04-13 08:42:33 166浏览 收藏

对于一个Golang开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《如何使用 Server.TLSNextProto 禁用 HTTP/2》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

问题内容

我有一个处理 https 请求的 go 服务器:

package main
import (
        "fmt"
        "net/http"
        "log"
)
const (
        port       = "5966"
        cert       = "/tmp/cert.pem"
        key        = "/tmp/key.pem"
)
func main() {

        listen_at := ":" + port
        fmt.Println("Listening at", listen_at)
        go http.HandleFunc("/job_handler/", job_handler)
        log.Fatal(http.ListenAndServeTLS(listen_at, cert, key, nil))
}
func job_handler(w http.ResponseWriter, r *http.Request) {
       // do somework
}

原来在https模式下,go对http/2协议有透明的支持。我们的一些客户端在 http/2 中表现明显不正常,因此我们需要在服务器端禁用 http/2。

不幸的是,我无法使用 env 变量 godebug=http2server=0 来禁用 http/2。剩下的是 server.tlsnextproto ,如此处记录。

如何在上面的服务器代码上使用 server.tlsnextproto 来禁用 https/2?


解决方案


禁用 http/2 的最简单设置是

package main

import (
    "log"
    "net/http"
    "crypto/tls"
)

func main() {

    m := http.newservemux()

    srv := &http.server{
        handler:      m,
        addr:         "127.0.0.1:8080",
        tlsnextproto: make(map[string]func(*http.server, *tls.conn, http.handler)),
    }

    log.fatal(srv.listenandserve())

}

您可以通过以下方式验证支持

curl -v --http2-prior-knowledge http://localhost:8080

本篇关于《如何使用 Server.TLSNextProto 禁用 HTTP/2》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>