Merge pull request #2117 from filbranden/detection1
Remove libcontainer detection for systemd features
This commit is contained in:
commit
3525eddec5
|
@ -73,9 +73,6 @@ const (
|
||||||
var (
|
var (
|
||||||
connLock sync.Mutex
|
connLock sync.Mutex
|
||||||
theConn *systemdDbus.Conn
|
theConn *systemdDbus.Conn
|
||||||
hasStartTransientUnit bool
|
|
||||||
hasStartTransientSliceUnit bool
|
|
||||||
hasDelegateSlice bool
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func newProp(name string, units interface{}) systemdDbus.Property {
|
func newProp(name string, units interface{}) systemdDbus.Property {
|
||||||
|
@ -114,67 +111,8 @@ func UseSystemd() bool {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assume we have StartTransientUnit
|
|
||||||
hasStartTransientUnit = true
|
|
||||||
|
|
||||||
// But if we get UnknownMethod error we don't
|
|
||||||
if _, err := theConn.StartTransientUnit("test.scope", "invalid", nil, nil); err != nil {
|
|
||||||
if dbusError, ok := err.(dbus.Error); ok {
|
|
||||||
if dbusError.Name == "org.freedesktop.DBus.Error.UnknownMethod" {
|
|
||||||
hasStartTransientUnit = false
|
|
||||||
return hasStartTransientUnit
|
|
||||||
}
|
}
|
||||||
}
|
return true
|
||||||
}
|
|
||||||
|
|
||||||
// Assume we have the ability to start a transient unit as a slice
|
|
||||||
// This was broken until systemd v229, but has been back-ported on RHEL environments >= 219
|
|
||||||
// For details, see: https://bugzilla.redhat.com/show_bug.cgi?id=1370299
|
|
||||||
hasStartTransientSliceUnit = true
|
|
||||||
|
|
||||||
// To ensure simple clean-up, we create a slice off the root with no hierarchy
|
|
||||||
slice := fmt.Sprintf("libcontainer_%d_systemd_test_default.slice", os.Getpid())
|
|
||||||
if _, err := theConn.StartTransientUnit(slice, "replace", nil, nil); err != nil {
|
|
||||||
if _, ok := err.(dbus.Error); ok {
|
|
||||||
hasStartTransientSliceUnit = false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for i := 0; i <= testSliceWait; i++ {
|
|
||||||
if _, err := theConn.StopUnit(slice, "replace", nil); err != nil {
|
|
||||||
if dbusError, ok := err.(dbus.Error); ok {
|
|
||||||
if strings.Contains(dbusError.Name, "org.freedesktop.systemd1.NoSuchUnit") {
|
|
||||||
hasStartTransientSliceUnit = false
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
time.Sleep(time.Millisecond)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Not critical because of the stop unit logic above.
|
|
||||||
theConn.StopUnit(slice, "replace", nil)
|
|
||||||
|
|
||||||
// Assume StartTransientUnit on a slice allows Delegate
|
|
||||||
hasDelegateSlice = true
|
|
||||||
dlSlice := newProp("Delegate", true)
|
|
||||||
if _, err := theConn.StartTransientUnit(slice, "replace", []systemdDbus.Property{dlSlice}, nil); err != nil {
|
|
||||||
if dbusError, ok := err.(dbus.Error); ok {
|
|
||||||
// Starting with systemd v237, Delegate is not even a property of slices anymore,
|
|
||||||
// so the D-Bus call fails with "InvalidArgs" error.
|
|
||||||
if strings.Contains(dbusError.Name, "org.freedesktop.DBus.Error.PropertyReadOnly") || strings.Contains(dbusError.Name, "org.freedesktop.DBus.Error.InvalidArgs") {
|
|
||||||
hasDelegateSlice = false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Not critical because of the stop unit logic above.
|
|
||||||
theConn.StopUnit(slice, "replace", nil)
|
|
||||||
}
|
|
||||||
return hasStartTransientUnit
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewSystemdCgroupsManager() (func(config *configs.Cgroup, paths map[string]string) cgroups.Manager, error) {
|
func NewSystemdCgroupsManager() (func(config *configs.Cgroup, paths map[string]string) cgroups.Manager, error) {
|
||||||
|
@ -222,10 +160,6 @@ func (m *Manager) Apply(pid int) error {
|
||||||
|
|
||||||
// if we create a slice, the parent is defined via a Wants=
|
// if we create a slice, the parent is defined via a Wants=
|
||||||
if strings.HasSuffix(unitName, ".slice") {
|
if strings.HasSuffix(unitName, ".slice") {
|
||||||
// This was broken until systemd v229, but has been back-ported on RHEL environments >= 219
|
|
||||||
if !hasStartTransientSliceUnit {
|
|
||||||
return fmt.Errorf("systemd version does not support ability to start a slice as transient unit")
|
|
||||||
}
|
|
||||||
properties = append(properties, systemdDbus.PropWants(slice))
|
properties = append(properties, systemdDbus.PropWants(slice))
|
||||||
} else {
|
} else {
|
||||||
// otherwise, we use Slice=
|
// otherwise, we use Slice=
|
||||||
|
@ -238,12 +172,7 @@ func (m *Manager) Apply(pid int) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if we can delegate. This is only supported on systemd versions 218 and above.
|
// Check if we can delegate. This is only supported on systemd versions 218 and above.
|
||||||
if strings.HasSuffix(unitName, ".slice") {
|
if !strings.HasSuffix(unitName, ".slice") {
|
||||||
if hasDelegateSlice {
|
|
||||||
// systemd 237 and above no longer allows delegation on a slice
|
|
||||||
properties = append(properties, newProp("Delegate", true))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Assume scopes always support delegation.
|
// Assume scopes always support delegation.
|
||||||
properties = append(properties, newProp("Delegate", true))
|
properties = append(properties, newProp("Delegate", true))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue