У меня есть сервер Go, обрабатывающий запросы https:
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?