runc/libcontainer/system
Michael Crosby fdb100d247 Destroy container along with processes before stdio
We need to make sure the container is destroyed before closing the stdio
for the container.  This becomes a big issues when running in the host's
pid namespace because the other processes could have inherited the stdio
of the initial process.  The call to close will just block as they still
have the io open.

Calling destroy before closing io, especially in the host pid namespace
will cause all additional processes to be killed in the container's
cgroup.  This will allow the io to be closed successfuly.

This change makes sure the order for destroy and close is correct as
well as ensuring that if any errors encoutered during start or exec will
be handled by terminating the process and destroying the container.  We
cannot use defers here because we need to enforce the correct ordering
on destroy.

This also sets the subreaper setting for runc so that when running in
pid host, runc can wait on the addiontal processes launched by the
container, useful on destroy, but also good for reaping the additional
processes that were launched.

Signed-off-by: Michael Crosby <crosbymichael@gmail.com>
2016-03-15 13:17:11 -07:00
..
linux.go Destroy container along with processes before stdio 2016-03-15 13:17:11 -07:00
proc.go Move libcontainer into subdirectory 2015-06-21 19:29:15 -07:00
setns_linux.go Move libcontainer into subdirectory 2015-06-21 19:29:15 -07:00
syscall_linux_64.go Move libcontainer into subdirectory 2015-06-21 19:29:15 -07:00
syscall_linux_386.go Fix build tags 2015-07-01 13:22:09 -07:00
syscall_linux_arm.go Fix build tags 2015-07-01 13:22:09 -07:00
sysconfig.go Move libcontainer into subdirectory 2015-06-21 19:29:15 -07:00
sysconfig_notcgo.go Move libcontainer into subdirectory 2015-06-21 19:29:15 -07:00
unsupported.go Stub RunningInUserNS for non-Linux 2016-03-03 16:33:43 -05:00
xattrs_linux.go Move libcontainer into subdirectory 2015-06-21 19:29:15 -07:00