From f35382325ab9324609ae29b4128e3cfdb5110dc7 Mon Sep 17 00:00:00 2001 From: Nikita Kryuchkov Date: Mon, 9 Mar 2020 19:39:43 +0100 Subject: [PATCH] Copy exec.Command on Start() failure --- pkg/restart/restart.go | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/pkg/restart/restart.go b/pkg/restart/restart.go index 4733508129..6cfd6361f3 100644 --- a/pkg/restart/restart.go +++ b/pkg/restart/restart.go @@ -36,20 +36,17 @@ type Context struct { // Data used by CaptureContext must not be modified before, // therefore calling CaptureContext immediately after starting executable is recommended. func CaptureContext() *Context { - return &Context{ - cmd: captureCmd(), - checkDelay: DefaultCheckDelay, - appendDelay: true, - } -} - -func captureCmd() *exec.Cmd { cmd := exec.Command(os.Args[0], os.Args[1:]...) // nolint:gosec cmd.Stdout = os.Stdout cmd.Stdin = os.Stdin cmd.Stderr = os.Stderr cmd.Env = os.Environ() - return cmd + + return &Context{ + cmd: cmd, + checkDelay: DefaultCheckDelay, + appendDelay: true, + } } // RegisterLogger registers a logger instead of standard one. @@ -85,7 +82,7 @@ func (c *Context) Start() (err error) { c.errorLogger()("Failed to start new instance: %v", err) // Reset c.cmd on failure so it can be reused. - c.cmd = captureCmd() + c.cmd = copyCmd(c.cmd) atomic.StoreInt32(&c.isStarted, 0) case <-ticker.C: @@ -96,6 +93,16 @@ func (c *Context) Start() (err error) { return err } +func copyCmd(oldCmd *exec.Cmd) *exec.Cmd { + newCmd := exec.Command(oldCmd.Path, oldCmd.Args...) // nolint:gosec + newCmd.Stdout = oldCmd.Stdout + newCmd.Stdin = oldCmd.Stdin + newCmd.Stderr = oldCmd.Stderr + newCmd.Env = oldCmd.Env + + return newCmd +} + func (c *Context) startExec() chan error { errCh := make(chan error, 1)