Merge pull request #392 from mrunalp/poststart

Add poststart hooks
This commit is contained in:
Michael Crosby 2015-11-12 16:34:38 -08:00
commit 2be14dc963
3 changed files with 27 additions and 0 deletions

View File

@ -183,6 +183,9 @@ type Hooks struct {
// but before the user supplied command is executed from init. // but before the user supplied command is executed from init.
Prestart []Hook Prestart []Hook
// Poststart commands are executed after the container init process starts.
Poststart []Hook
// Poststop commands are executed after the container init process exits. // Poststop commands are executed after the container init process exits.
Poststop []Hook Poststop []Hook
} }

View File

@ -182,6 +182,22 @@ func (c *linuxContainer) Start(process *Process) error {
if doInit { if doInit {
c.updateState(parent) c.updateState(parent)
} }
if c.config.Hooks != nil {
s := configs.HookState{
Version: c.config.Version,
ID: c.id,
Pid: parent.pid(),
Root: c.config.Rootfs,
}
for _, hook := range c.config.Hooks.Poststart {
if err := hook.Run(s); err != nil {
if err := parent.terminate(); err != nil {
logrus.Warn(err)
}
return newSystemError(err)
}
}
}
return nil return nil
} }

View File

@ -712,6 +712,14 @@ func createHooks(rspec *specs.LinuxRuntimeSpec, config *configs.Config) {
} }
config.Hooks.Prestart = append(config.Hooks.Prestart, configs.NewCommandHook(cmd)) config.Hooks.Prestart = append(config.Hooks.Prestart, configs.NewCommandHook(cmd))
} }
for _, h := range rspec.Hooks.Poststart {
cmd := configs.Command{
Path: h.Path,
Args: h.Args,
Env: h.Env,
}
config.Hooks.Poststart = append(config.Hooks.Poststart, configs.NewCommandHook(cmd))
}
for _, h := range rspec.Hooks.Poststop { for _, h := range rspec.Hooks.Poststop {
cmd := configs.Command{ cmd := configs.Command{
Path: h.Path, Path: h.Path,