diff options
author | zeripath <art27@cantab.net> | 2021-06-30 21:07:23 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-30 22:07:23 +0200 |
commit | 302e8b6d02dc9ccac00284b3cdf9a69c001882c0 (patch) | |
tree | fd8a57a78924df719b8c6771d59c6577b163b659 /modules/markup/external | |
parent | 365c4e9316bbcc8bdf9cf68ef237bf18ae8db315 (diff) | |
download | gitea-302e8b6d02dc9ccac00284b3cdf9a69c001882c0.tar.gz gitea-302e8b6d02dc9ccac00284b3cdf9a69c001882c0.zip |
Prevent zombie processes (#16314)
Unfortunately go doesn't always ensure that execd processes are completely
waited for. On linux this means that zombie processes can occur.
This PR ensures that these are waited for by using signal notifier in serv and
passing a context elsewhere.
Signed-off-by: Andrew Thornton <art27@cantab.net>
Diffstat (limited to 'modules/markup/external')
-rw-r--r-- | modules/markup/external/external.go | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/modules/markup/external/external.go b/modules/markup/external/external.go index c849f505e7..e35a1b99c0 100644 --- a/modules/markup/external/external.go +++ b/modules/markup/external/external.go @@ -5,6 +5,7 @@ package external import ( + "context" "fmt" "io" "io/ioutil" @@ -15,6 +16,7 @@ import ( "code.gitea.io/gitea/modules/log" "code.gitea.io/gitea/modules/markup" + "code.gitea.io/gitea/modules/process" "code.gitea.io/gitea/modules/setting" "code.gitea.io/gitea/modules/util" ) @@ -96,7 +98,13 @@ func (p *Renderer) Render(ctx *markup.RenderContext, input io.Reader, output io. args = append(args, f.Name()) } - cmd := exec.Command(commands[0], args...) + processCtx, cancel := context.WithCancel(ctx.Ctx) + defer cancel() + + pid := process.GetManager().Add(fmt.Sprintf("Render [%s] for %s", commands[0], ctx.URLPrefix), cancel) + defer process.GetManager().Remove(pid) + + cmd := exec.CommandContext(processCtx, commands[0], args...) cmd.Env = append( os.Environ(), "GITEA_PREFIX_SRC="+ctx.URLPrefix, |