Mathieu found the culprit, many thanks! This is due to some cleanup code in udevd which wreaks havoc when not running under systemd, as it assumes that it runs in its own cgroup (normally /system.slice/systemd- udevd.service). src/udev/udevd.c on_post() has:
} else if (manager->cgroup) /* cleanup possible left-over processes in our cgroup */ cg_kill(SYSTEMD_CGROUP_CONTROLLER, manager->cgroup, SIGKILL, false, true, NULL); But under upstart processes don't run in cgroups, and hence manager->cgroup is (almost surely) "/" and thus it kills all running processes. We need to disarm this to only clean up if the cgroup is not empty. This can be reproduced fairly easily: - Boot a trusty VM (cloud-image/autopkgtest image is fine) - Install udisks2 - Change apt sources to xenial, install udev from xenial - apt-get install --reinstall udisks2 The last command triggers udev rules and causes most processes to get killed and restarted, which can be seen nicely in their startup time and in /var/log/syslog. ** Changed in: systemd (Ubuntu) Milestone: None => ubuntu-16.04 -- You received this bug notification because you are a member of Ubuntu Bugs, which is subscribed to Ubuntu. https://bugs.launchpad.net/bugs/1555237 Title: Upgrade from 14.04.4→ 16.04 dies midway taking out the session. To manage notifications about this bug go to: https://bugs.launchpad.net/ubuntu/+source/dbus/+bug/1555237/+subscriptions -- ubuntu-bugs mailing list ubuntu-bugs@lists.ubuntu.com https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs