Skip to content

Commit 7523314

Browse files
authored
Graceful: Allow graceful restart for fcgi (#9112)
* Graceful: Allow graceful restart for fcgi My previous interpretation was incorrect - we do not handle sockets being passed in over stdin * Update web.go
1 parent d779dee commit 7523314

File tree

2 files changed

+18
-16
lines changed

2 files changed

+18
-16
lines changed

cmd/web.go

Lines changed: 1 addition & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,7 @@ package cmd
66

77
import (
88
"fmt"
9-
"net"
109
"net/http"
11-
"net/http/fcgi"
1210
_ "net/http/pprof" // Used for debugging if enabled and a web server is running
1311
"os"
1412
"strings"
@@ -185,20 +183,7 @@ func runWeb(ctx *cli.Context) error {
185183
err = runHTTPS("tcp", listenAddr, setting.CertFile, setting.KeyFile, context2.ClearHandler(m))
186184
case setting.FCGI:
187185
NoHTTPRedirector()
188-
// FCGI listeners are provided as stdin - this is orthogonal to the LISTEN_FDS approach
189-
// in graceful and systemD
190-
NoMainListener()
191-
var listener net.Listener
192-
listener, err = net.Listen("tcp", listenAddr)
193-
if err != nil {
194-
log.Fatal("Failed to bind %s: %v", listenAddr, err)
195-
}
196-
defer func() {
197-
if err := listener.Close(); err != nil {
198-
log.Fatal("Failed to stop server: %v", err)
199-
}
200-
}()
201-
err = fcgi.Serve(listener, context2.ClearHandler(m))
186+
err = runFCGI(listenAddr, context2.ClearHandler(m))
202187
case setting.UnixSocket:
203188
NoHTTPRedirector()
204189
err = runHTTP("unix", listenAddr, context2.ClearHandler(m))

cmd/web_graceful.go

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,12 @@ package cmd
66

77
import (
88
"crypto/tls"
9+
"net"
910
"net/http"
11+
"net/http/fcgi"
1012

1113
"code.gitea.io/gitea/modules/graceful"
14+
"code.gitea.io/gitea/modules/log"
1215
)
1316

1417
func runHTTP(network, listenAddr string, m http.Handler) error {
@@ -33,3 +36,17 @@ func NoHTTPRedirector() {
3336
func NoMainListener() {
3437
graceful.Manager.InformCleanup()
3538
}
39+
40+
func runFCGI(listenAddr string, m http.Handler) error {
41+
// This needs to handle stdin as fcgi point
42+
fcgiServer := graceful.NewServer("tcp", listenAddr)
43+
44+
err := fcgiServer.ListenAndServe(func(listener net.Listener) error {
45+
return fcgi.Serve(listener, m)
46+
})
47+
if err != nil {
48+
log.Fatal("Failed to start FCGI main server: %v", err)
49+
}
50+
log.Info("FCGI Listener: %s Closed", listenAddr)
51+
return err
52+
}

0 commit comments

Comments
 (0)