Add request timeouts.

This commit is contained in:
FireMasterK 2021-03-12 12:29:53 +05:30
parent 0badc6c3d7
commit 17bc0c3321
No known key found for this signature in database
GPG key ID: 8DFF5DD33E93DB58

24
main.go
View file

@ -10,6 +10,7 @@ import (
"os" "os"
"strings" "strings"
"syscall" "syscall"
"time"
"github.com/lucas-clemente/quic-go/http3" "github.com/lucas-clemente/quic-go/http3"
) )
@ -20,7 +21,18 @@ var h3client = &http.Client{
} }
// http/2 client // http/2 client
var h2client = &http.Client{} var h2client = &http.Client{
Transport: &http.Transport{
Dial: (&net.Dialer{
Timeout: 30 * time.Second,
KeepAlive: 30 * time.Second,
}).Dial,
TLSHandshakeTimeout: 10 * time.Second,
ResponseHeaderTimeout: 10 * time.Second,
ExpectContinueTimeout: 1 * time.Second,
IdleConnTimeout: 120 * time.Second,
},
}
// user agent to use // user agent to use
var ua = "Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101" var ua = "Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101"
@ -141,12 +153,18 @@ func main() {
socket := "socket" + string(os.PathSeparator) + "http-proxy.sock" socket := "socket" + string(os.PathSeparator) + "http-proxy.sock"
syscall.Unlink(socket) syscall.Unlink(socket)
listener, err := net.Listen("unix", socket) listener, err := net.Listen("unix", socket)
srv := &http.Server{
ReadTimeout: 5 * time.Second,
WriteTimeout: 10 * time.Second,
Addr: ":8080",
Handler: &requesthandler{},
}
if err != nil { if err != nil {
fmt.Println("Failed to bind to UDS, falling back to TCP/IP") fmt.Println("Failed to bind to UDS, falling back to TCP/IP")
fmt.Println(err.Error()) fmt.Println(err.Error())
http.ListenAndServe(":8080", &requesthandler{}) srv.ListenAndServe()
} else { } else {
defer listener.Close() defer listener.Close()
http.Serve(listener, &requesthandler{}) srv.Serve(listener)
} }
} }