Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ( // ErrMissingCommand is the error returned when no command is specified // to run. ErrMissingCommand = errors.New("missing command") // ExitCodeOK is the default OK exit code. ExitCodeOK = 0 // ExitCodeError is the default error code returned when the child exits with // an error without a more specific code. ExitCodeError = 127 )
Functions ¶
func CommandPrep ¶ added in v0.31.100
Evaluates the command slice for the different possible formats. Returns the command slice ready to pass to exec.Command. Returns a boolean 'true' if it wrapped the call in 'sh -c' so the caller knows it needs to setpgid to get signal propagation.
Types ¶
type Child ¶
Child is a wrapper around a child process which can be used to send signals and manage the processes' lifecycle.
func New ¶
New creates a new child process for management with high-level APIs for sending signals to the child process, restarting the child process, and gracefully terminating the child process.
func (*Child) Command ¶ added in v0.18.0
Command returns the human-formatted command with arguments.
func (*Child) ExitCh ¶
ExitCh returns the current exit channel for this child process. This channel may change if the process is restarted, so implementers must not cache this value.
func (*Child) Kill ¶
func (c *Child) Kill()
Kill sends the kill signal to the child process and waits for successful termination. If no kill signal is defined, the process is killed with the most aggressive kill signal. If the process does not gracefully stop within the provided KillTimeout, the process is force-killed. If a splay was provided, this function will sleep for a random period of time between 0 and the provided splay value to reduce the thundering herd problem. This function does not return any errors because it guarantees the process will be dead by the return of the function call.
func (*Child) Pid ¶
Pid returns the pid of the child process. If no child process exists, 0 is returned.
func (*Child) Reload ¶
Reload sends the reload signal to the child process and does not wait for a response. If no reload signal was provided, the process is restarted and replaces the process attached to this Child.
func (*Child) Signal ¶
Signal sends the signal to the child process, returning any errors that occur.
func (*Child) Start ¶
Start starts and begins execution of the child process. A buffered channel is returned which is where the command's exit code will be returned upon exit. Any errors that occur prior to starting the command will be returned as the second error argument, but any errors returned by the command after execution will be returned as a non-zero value over the exit code channel.
func (*Child) Stop ¶
func (c *Child) Stop()
Stop behaves almost identical to Kill except it suppresses future processes from being started by this child and it prevents the killing of the child process from sending its value back up the exit channel. This is useful when doing a graceful shutdown of an application.
func (*Child) StopImmediately ¶ added in v0.31.100
func (c *Child) StopImmediately()
StopImmediately behaves almost identical to Stop except it does not wait for any random splay if configured. This is used for performing a fast shutdown of consul-template and its children when a kill signal is received.
type NewInput ¶
type NewInput struct { // Stdin is the io.Reader where input will come from. This is sent directly to // the child process. Stdout and Stderr represent the io.Writer objects where // the child process will send output and errorput. Stdin io.Reader Stdout, Stderr io.Writer // Command is the name of the command to execute. Args are the list of // arguments to pass when starting the command. Command string Args []string // Timeout is the maximum amount of time to allow the command to execute. If // set to 0, the command is permitted to run infinitely. Timeout time.Duration // Env represents the condition of the child processes' environment // variables. Only these environment variables will be given to the child, so // it is the responsibility of the caller to include the parent processes // environment, if required. This should be in the key=value format. Env []string // ReloadSignal is the signal to send to reload this process. This value may // be nil. ReloadSignal os.Signal // KillSignal is the signal to send to gracefully kill this process. This // value may be nil. KillSignal os.Signal // KillTimeout is the amount of time to wait for the process to gracefully // terminate before force-killing. KillTimeout time.Duration // Splay is the maximum random amount of time to wait before sending signals. // This option helps reduce the thundering herd problem by effectively // sleeping for a random amount of time before sending the signal. This // prevents multiple processes from all signaling at the same time. This value // may be zero (which disables the splay entirely). Splay time.Duration // Setsid flag, if set to true will create the child processes with their own // session ID and Process group ID. Note this overrides Setpgid below. Setsid bool // Setpgid flag, if set to true will create the child processes with their // own Process group ID. If set the child processes to have their own PGID // but they will have the same SID as that of their parent Setpgid bool // an optional logger that can be used for messages pertinent to the child process Logger *log.Logger }
NewInput is input to the NewChild function.