Merge pull request #2047 from estesp/use-libcontainer-subreaper-api
Remove unnecessary subreaper API from sys/
This commit is contained in:
commit
cee56a1226
@ -6,8 +6,8 @@ import (
|
|||||||
"syscall"
|
"syscall"
|
||||||
|
|
||||||
"github.com/containerd/containerd/reaper"
|
"github.com/containerd/containerd/reaper"
|
||||||
"github.com/containerd/containerd/sys"
|
|
||||||
runc "github.com/containerd/go-runc"
|
runc "github.com/containerd/go-runc"
|
||||||
|
"github.com/opencontainers/runc/libcontainer/system"
|
||||||
"github.com/stevvooe/ttrpc"
|
"github.com/stevvooe/ttrpc"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -20,7 +20,7 @@ func setupSignals() (chan os.Signal, error) {
|
|||||||
// for waiting on processes
|
// for waiting on processes
|
||||||
runc.Monitor = reaper.Default
|
runc.Monitor = reaper.Default
|
||||||
// set the shim as the subreaper for all orphaned processes created by the container
|
// set the shim as the subreaper for all orphaned processes created by the container
|
||||||
if err := sys.SetSubreaper(1); err != nil {
|
if err := system.SetSubreaper(1); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return signals, nil
|
return signals, nil
|
||||||
|
41
sys/prctl.go
41
sys/prctl.go
@ -1,41 +0,0 @@
|
|||||||
// +build linux
|
|
||||||
|
|
||||||
// Package sys provides access to the Get Child and Set Child prctl flags.
|
|
||||||
// See http://man7.org/linux/man-pages/man2/prctl.2.html
|
|
||||||
package sys
|
|
||||||
|
|
||||||
import (
|
|
||||||
"unsafe"
|
|
||||||
|
|
||||||
"golang.org/x/sys/unix"
|
|
||||||
)
|
|
||||||
|
|
||||||
// GetSubreaper returns the subreaper setting for the calling process
|
|
||||||
func GetSubreaper() (int, error) {
|
|
||||||
var i uintptr
|
|
||||||
// PR_GET_CHILD_SUBREAPER allows retrieving the current child
|
|
||||||
// subreaper.
|
|
||||||
// Returns the "child subreaper" setting of the caller, in the
|
|
||||||
// location pointed to by (int *) arg2.
|
|
||||||
if err := unix.Prctl(unix.PR_GET_CHILD_SUBREAPER, uintptr(unsafe.Pointer(&i)), 0, 0, 0); err != nil {
|
|
||||||
return -1, err
|
|
||||||
}
|
|
||||||
return int(i), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetSubreaper sets the value i as the subreaper setting for the calling process
|
|
||||||
func SetSubreaper(i int) error {
|
|
||||||
// PR_SET_CHILD_SUBREAPER allows setting the child subreaper.
|
|
||||||
// If arg2 is nonzero, set the "child subreaper" attribute of the
|
|
||||||
// calling process; if arg2 is zero, unset the attribute. When a
|
|
||||||
// process is marked as a child subreaper, all of the children
|
|
||||||
// that it creates, and their descendants, will be marked as
|
|
||||||
// having a subreaper. In effect, a subreaper fulfills the role
|
|
||||||
// of init(1) for its descendant processes. Upon termination of
|
|
||||||
// a process that is orphaned (i.e., its immediate parent has
|
|
||||||
// already terminated) and marked as having a subreaper, the
|
|
||||||
// nearest still living ancestor subreaper will receive a SIGCHLD
|
|
||||||
// signal and be able to wait(2) on the process to discover its
|
|
||||||
// termination status.
|
|
||||||
return unix.Prctl(unix.PR_SET_CHILD_SUBREAPER, uintptr(i), 0, 0, 0)
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user