new quic release 1
All checks were successful
Create and publish a Docker image 🚀 / build-and-push-image (push) Successful in 1m7s
All checks were successful
Create and publish a Docker image 🚀 / build-and-push-image (push) Successful in 1m7s
This commit is contained in:
12
go.mod
12
go.mod
@@ -1,15 +1,3 @@
|
||||
module qgo
|
||||
|
||||
go 1.25.0
|
||||
|
||||
require (
|
||||
github.com/quic-go/quic-go v0.59.0
|
||||
golang.org/x/crypto v0.48.0
|
||||
)
|
||||
|
||||
require (
|
||||
github.com/quic-go/qpack v0.6.0 // indirect
|
||||
golang.org/x/net v0.50.0 // indirect
|
||||
golang.org/x/sys v0.41.0 // indirect
|
||||
golang.org/x/text v0.34.0 // indirect
|
||||
)
|
||||
|
||||
22
go.sum
22
go.sum
@@ -1,22 +0,0 @@
|
||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||
github.com/quic-go/qpack v0.6.0 h1:g7W+BMYynC1LbYLSqRt8PBg5Tgwxn214ZZR34VIOjz8=
|
||||
github.com/quic-go/qpack v0.6.0/go.mod h1:lUpLKChi8njB4ty2bFLX2x4gzDqXwUpaO1DP9qMDZII=
|
||||
github.com/quic-go/quic-go v0.59.0 h1:OLJkp1Mlm/aS7dpKgTc6cnpynnD2Xg7C1pwL6vy/SAw=
|
||||
github.com/quic-go/quic-go v0.59.0/go.mod h1:upnsH4Ju1YkqpLXC305eW3yDZ4NfnNbmQRCMWS58IKU=
|
||||
github.com/stretchr/testify v1.11.1 h1:7s2iGBzp5EwR7/aIZr8ao5+dra3wiQyKjjFuvgVKu7U=
|
||||
github.com/stretchr/testify v1.11.1/go.mod h1:wZwfW3scLgRK+23gO65QZefKpKQRnfz6sD981Nm4B6U=
|
||||
go.uber.org/mock v0.5.2 h1:LbtPTcP8A5k9WPXj54PPPbjcI4Y6lhyOZXn+VS7wNko=
|
||||
go.uber.org/mock v0.5.2/go.mod h1:wLlUxC2vVTPTaE3UD51E0BGOAElKrILxhVSDYQLld5o=
|
||||
golang.org/x/crypto v0.48.0 h1:/VRzVqiRSggnhY7gNRxPauEQ5Drw9haKdM0jqfcCFts=
|
||||
golang.org/x/crypto v0.48.0/go.mod h1:r0kV5h3qnFPlQnBSrULhlsRfryS2pmewsg+XfMgkVos=
|
||||
golang.org/x/net v0.50.0 h1:ucWh9eiCGyDR3vtzso0WMQinm2Dnt8cFMuQa9K33J60=
|
||||
golang.org/x/net v0.50.0/go.mod h1:UgoSli3F/pBgdJBHCTc+tp3gmrU4XswgGRgtnwWTfyM=
|
||||
golang.org/x/sys v0.41.0 h1:Ivj+2Cp/ylzLiEU89QhWblYnOE9zerudt9Ftecq2C6k=
|
||||
golang.org/x/sys v0.41.0/go.mod h1:OgkHotnGiDImocRcuBABYBEXf8A9a87e/uXjp9XT3ks=
|
||||
golang.org/x/text v0.34.0 h1:oL/Qq0Kdaqxa1KbNeMKwQq0reLCCaFtqu2eNuSeNHbk=
|
||||
golang.org/x/text v0.34.0/go.mod h1:homfLqTYRFyVYemLBFl5GgL/DWEiH5wcsQ5gSh1yziA=
|
||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||
|
||||
47
main.go
47
main.go
@@ -3,53 +3,22 @@ package main
|
||||
import (
|
||||
"fmt"
|
||||
"net/http"
|
||||
|
||||
"github.com/quic-go/quic-go/http3"
|
||||
"golang.org/x/crypto/acme/autocert"
|
||||
)
|
||||
|
||||
func main() {
|
||||
certManager := autocert.Manager{
|
||||
Prompt: autocert.AcceptTOS,
|
||||
HostPolicy: autocert.HostWhitelist("qgo-server.quizer.space"),
|
||||
Cache: autocert.DirCache("certs"), // Папка для хранения сертификатов
|
||||
}
|
||||
|
||||
mux := http.NewServeMux()
|
||||
mux.HandleFunc("/api/hello", func(w http.ResponseWriter, r *http.Request) {
|
||||
// Сообщаем браузеру, что мы работаем на h3 на 443 порту
|
||||
// ВАЖНО: Этот заголовок заставляет браузер переключиться на UDP
|
||||
w.Header().Set("Alt-Svc", `h3=":443"; ma=86400`)
|
||||
|
||||
// CORS (если нужно для Svelte)
|
||||
w.Header().Set("Access-Control-Allow-Origin", "*")
|
||||
|
||||
// Лог в консоль сервера, чтобы видеть реальный протокол
|
||||
fmt.Printf("Запрос: %s | Протокол: %s\n", r.URL.Path, r.Proto)
|
||||
w.Write([]byte(fmt.Sprintf("Привет! Это честный QUIC. Протокол: %s", r.Proto)))
|
||||
// Логируем протокол. Traefik v3 передает информацию о QUIC в заголовках
|
||||
fmt.Printf("Запрос от Traefik. Протокол: %s\n", r.Proto)
|
||||
w.Write([]byte("Данные переданы через QUIC (UDP) до Traefik!"))
|
||||
})
|
||||
|
||||
// Настройка TLS для поддержки QUIC и ACME (Let's Encrypt)
|
||||
tlsConfig := certManager.TLSConfig()
|
||||
tlsConfig.NextProtos = []string{"h3", "h3-29", "h2", "http/1.1"}
|
||||
|
||||
// 1. Запуск проверки Let's Encrypt (порт 80)
|
||||
go http.ListenAndServe(":80", certManager.HTTPHandler(nil))
|
||||
|
||||
// 2. Запуск QUIC (UDP)
|
||||
go func() {
|
||||
server := &http3.Server{
|
||||
Addr: ":443",
|
||||
Handler: mux,
|
||||
TLSConfig: tlsConfig,
|
||||
}
|
||||
fmt.Println("QUIC сервер слушает UDP :443")
|
||||
server.ListenAndServe()
|
||||
}()
|
||||
|
||||
// 3. Запуск HTTPS (TCP) - нужен для первого рукопожатия браузера
|
||||
fmt.Println("HTTPS сервер слушает TCP :443")
|
||||
server := &http.Server{
|
||||
Addr: ":443",
|
||||
Handler: mux,
|
||||
TLSConfig: tlsConfig,
|
||||
}
|
||||
server.ListenAndServeTLS("", "")
|
||||
// Слушаем обычный порт внутри контейнера
|
||||
http.ListenAndServe(":8080", mux)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user