Skip to content

Commit

Permalink
fix: Prefer os.Process.Signal to syscall.Kill
Browse files Browse the repository at this point in the history
This helps protect us from a potential (but extremely rare) race
condition where

1. the process exits terminates
2. its PID gets reaped in the Wait call
3. a new process with the same PID gets spawned

before our signal actually gets sent.

This uses the higher-level os.Process API directly, which has some
synchronization in-place to prevent Wait and Signal from racing.
  • Loading branch information
anrddh committed Aug 19, 2024
1 parent 044b71d commit d84bf09
Showing 1 changed file with 1 addition and 1 deletion.
2 changes: 1 addition & 1 deletion src/command/stopper_unix.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ func (c *CmdWrapper) Stop(sig int, parentOnly bool) error {
Msg("Stop Unix process.")

if parentOnly {
return syscall.Kill(c.Pid(), syscall.Signal(sig))
return c.cmd.Process.Signal(syscall.Signal(sig))
}

pgid, err := syscall.Getpgid(c.Pid())
Expand Down

0 comments on commit d84bf09

Please sign in to comment.