summaryrefslogtreecommitdiffstats
path: root/upstream/archlinux/man7/systemd.offline-updates.7
diff options
context:
space:
mode:
Diffstat (limited to 'upstream/archlinux/man7/systemd.offline-updates.7')
-rw-r--r--upstream/archlinux/man7/systemd.offline-updates.7263
1 files changed, 263 insertions, 0 deletions
diff --git a/upstream/archlinux/man7/systemd.offline-updates.7 b/upstream/archlinux/man7/systemd.offline-updates.7
new file mode 100644
index 00000000..3c098cce
--- /dev/null
+++ b/upstream/archlinux/man7/systemd.offline-updates.7
@@ -0,0 +1,263 @@
+'\" t
+.TH "SYSTEMD\&.OFFLINE\-UPDATES" "7" "" "systemd 255" "systemd.offline-updates"
+.\" -----------------------------------------------------------------
+.\" * Define some portability stuff
+.\" -----------------------------------------------------------------
+.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+.\" http://bugs.debian.org/507673
+.\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html
+.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+.ie \n(.g .ds Aq \(aq
+.el .ds Aq '
+.\" -----------------------------------------------------------------
+.\" * set default formatting
+.\" -----------------------------------------------------------------
+.\" disable hyphenation
+.nh
+.\" disable justification (adjust text to left margin only)
+.ad l
+.\" -----------------------------------------------------------------
+.\" * MAIN CONTENT STARTS HERE *
+.\" -----------------------------------------------------------------
+.SH "NAME"
+systemd.offline-updates \- Implementation of offline updates in systemd
+.SH "IMPLEMENTING OFFLINE SYSTEM UPDATES"
+.PP
+This man page describes how to implement "offline" system updates with systemd\&. By "offline" OS updates we mean package installations and updates that are run with the system booted into a special system update mode, in order to avoid problems related to conflicts of libraries and services that are currently running with those on disk\&. This document is inspired by this
+\m[blue]\fBGNOME design whiteboard\fR\m[]\&\s-2\u[1]\d\s+2\&.
+.PP
+The logic:
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 1.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 1." 4.2
+.\}
+The package manager prepares system updates by downloading all (\&.rpm or \&.deb or whatever) packages to update off\-line in a special directory
+/var/lib/system\-update
+(or another directory of the package/upgrade manager\*(Aqs choice)\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 2.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 2." 4.2
+.\}
+When the user OK\*(Aqed the update, the symlink
+/system\-update
+or
+/etc/system\-update
+is created that points to
+/var/lib/system\-update
+(or wherever the directory with the upgrade files is located) and the system is rebooted\&. This symlink is in the root directory, since we need to check for it very early at boot, at a time where
+/var/
+is not available yet\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 3.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 3." 4.2
+.\}
+Very early in the new boot
+\fBsystemd-system-update-generator\fR(8)
+checks whether
+/system\-update
+or
+/etc/system\-update
+exists\&. If so, it (temporarily and for this boot only) redirects (i\&.e\&. symlinks)
+default\&.target
+to
+system\-update\&.target, a special target that pulls in the base system (i\&.e\&.
+sysinit\&.target, so that all file systems are mounted but little else) and the system update units\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 4.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 4." 4.2
+.\}
+The system now continues to boot into
+default\&.target, and thus into
+system\-update\&.target\&. This target pulls in all system update units\&. Only one service should perform an update (see the next point), and all the other ones should exit cleanly with a "success" return code and without doing anything\&. Update services should be ordered after
+sysinit\&.target
+so that the update starts after all file systems have been mounted\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 5.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 5." 4.2
+.\}
+As the first step, an update service should check if the
+/system\-update
+or
+/etc/system\-update
+symlink points to the location used by that update service\&. In case it does not exist or points to a different location, the service must exit without error\&. It is possible for multiple update services to be installed, and for multiple update services to be launched in parallel, and only the one that corresponds to the tool that
+\fIcreated\fR
+the symlink before reboot should perform any actions\&. It is unsafe to run multiple updates in parallel\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 6.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 6." 4.2
+.\}
+The update service should now do its job\&. If applicable and possible, it should create a file system snapshot, then install all packages\&. After completion (regardless whether the update succeeded or failed) the machine must be rebooted, for example by calling
+\fBsystemctl reboot\fR\&. In addition, on failure the script should revert to the old file system snapshot (without the symlink)\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 7.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 7." 4.2
+.\}
+The update scripts should exit only after the update is finished\&. It is expected that the service which performs the update will cause the machine to reboot after it is done\&. If the
+system\-update\&.target
+is successfully reached, i\&.e\&. all update services have run, and the
+/system\-update
+or
+/etc/system\-update
+symlink still exists, it will be removed and the machine rebooted as a safety measure\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 8.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 8." 4.2
+.\}
+After a reboot, now that the
+/system\-update
+and
+/etc/system\-update
+symlink is gone, the generator won\*(Aqt redirect
+default\&.target
+anymore and the system now boots into the default target again\&.
+.RE
+.SH "RECOMMENDATIONS"
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 1.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 1." 4.2
+.\}
+To make things a bit more robust we recommend hooking the update script into
+system\-update\&.target
+via a
+\&.wants/
+symlink in the distribution package, rather than depending on
+\fBsystemctl enable\fR
+in the postinst scriptlets of your package\&. More specifically, for your update script create a \&.service file, without [Install] section, and then add a symlink like
+/usr/lib/systemd/system/system\-update\&.target\&.wants/foobar\&.service
+→
+\&.\&./foobar\&.service
+to your package\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 2.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 2." 4.2
+.\}
+Make sure to remove the
+/system\-update
+and
+/etc/system\-update
+symlinks as early as possible in the update script to avoid reboot loops in case the update fails\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 3.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 3." 4.2
+.\}
+Use
+\fIFailureAction=reboot\fR
+in the service file for your update script to ensure that a reboot is automatically triggered if the update fails\&.
+\fIFailureAction=\fR
+makes sure that the specified unit is activated if your script exits uncleanly (by non\-zero error code, or signal/coredump)\&. If your script succeeds you should trigger the reboot in your own code, for example by invoking logind\*(Aqs
+\fBReboot()\fR
+call or calling
+\fBsystemctl reboot\fR\&. See
+\fBorg.freedesktop.login1\fR(5)
+for details about the logind D\-Bus API\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 4.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 4." 4.2
+.\}
+The update service should declare
+\fIDefaultDependencies=no\fR,
+\fIRequires=sysinit\&.target\fR,
+\fIAfter=sysinit\&.target\fR,
+\fIAfter=system\-update\-pre\&.target\fR,
+\fIBefore=system\-update\&.target\fR
+and explicitly pull in any other services it requires\&.
+.RE
+.sp
+.RS 4
+.ie n \{\
+\h'-04' 5.\h'+01'\c
+.\}
+.el \{\
+.sp -1
+.IP " 5." 4.2
+.\}
+It may be desirable to always run an auxiliary unit when booting into offline\-updates mode, which itself does not install updates\&. To do this create a \&.service file with
+\fIWants=system\-update\-pre\&.target\fR
+and
+\fIBefore=system\-update\-pre\&.target\fR
+and add a symlink to that file under
+/usr/lib/systemd/system\-update\&.target\&.wants
+\&.
+.RE
+.SH "SEE ALSO"
+.PP
+\fBsystemd\fR(1),
+\fBsystemd.generator\fR(7),
+\fBsystemd-system-update-generator\fR(8),
+\fBdnf.plugin.system-upgrade\fR(8)
+.SH "NOTES"
+.IP " 1." 4
+GNOME design whiteboard
+.RS 4
+\%https://wiki.gnome.org/Design/OS/SoftwareUpdates
+.RE