summaryrefslogtreecommitdiffstats
path: root/modules/graceful
diff options
context:
space:
mode:
authorJonRB <4564448+eeyrjmr@users.noreply.github.com>2022-08-20 22:09:41 +0100
committerGitHub <noreply@github.com>2022-08-20 22:09:41 +0100
commitcb37c6ba5cc3c8113a7252e16b386eb887346185 (patch)
tree600a3453f8bfc1282e46a7d04d478e9038d8f47e /modules/graceful
parent3d52edc7a43ca429b7921b96c3663c32179881ab (diff)
downloadgitea-cb37c6ba5cc3c8113a7252e16b386eb887346185.tar.gz
gitea-cb37c6ba5cc3c8113a7252e16b386eb887346185.zip
call builtinUnused() if internal SSH is disabled (#20877)
The graceful manager waits for 4 listeners to be created or to be told that they are not needed. If it is not told about them it will indefinitely and timeout. This leads to SVC hosts not being told of being in the readyState but on Unix would lead to the termination of the process. There was an unfortunate regression in #20299 which missed this subtly and in the case whereby SSH is disabled the `builtinUnused()` is not called. This PR adds a call to `builtinUnused()` when not using the builtin ssh to allow `createServerWaitGroup.Done()` to be called. In addition it was noted that the if/else clauses for timeout informing of the SVC host were in the wrong order. These have been swapped. Fix #20609
Diffstat (limited to 'modules/graceful')
-rw-r--r--modules/graceful/manager_windows.go4
1 files changed, 2 insertions, 2 deletions
diff --git a/modules/graceful/manager_windows.go b/modules/graceful/manager_windows.go
index e7e619f53f..10c1d67b97 100644
--- a/modules/graceful/manager_windows.go
+++ b/modules/graceful/manager_windows.go
@@ -114,9 +114,9 @@ func (g *Manager) start() {
// Execute makes Manager implement svc.Handler
func (g *Manager) Execute(args []string, changes <-chan svc.ChangeRequest, status chan<- svc.Status) (svcSpecificEC bool, exitCode uint32) {
if setting.StartupTimeout > 0 {
- status <- svc.Status{State: svc.StartPending}
- } else {
status <- svc.Status{State: svc.StartPending, WaitHint: uint32(setting.StartupTimeout / time.Millisecond)}
+ } else {
+ status <- svc.Status{State: svc.StartPending}
}
log.Trace("Awaiting server start-up")