(→How To Test: link to copr repo, also exclude fwupd-offline-update.service) |
|||
Line 97: | Line 97: | ||
# Install <code>dnf-plugin-fedup</code> | # Install <code>dnf-plugin-fedup</code> | ||
#* From [https://github.com/wgwoods/dnf-plugin-fedup git] | #* From [https://github.com/wgwoods/dnf-plugin-fedup git] | ||
#* Or try the experimental package | #* Or try the experimental package<br><code>dnf copr enable zbyszek/dnf-plugin-fedup</code><br><code>dnf install 'dnf-command(fedup)'</code> | ||
# <code>systemctl mask packagekit-offline-update.service</code> | # <code>systemctl mask packagekit-offline-update.service fwupd-offline-update.service</code> | ||
# <code>dnf fedup download --releasever=23</code> | # <code>dnf fedup download --releasever=23</code> | ||
#* This should download lots of packages; it will probably also ask about importing the new GPG key. | #* This should download lots of packages; it will probably also ask about importing the new GPG key. | ||
Line 104: | Line 104: | ||
# Observe upgrade progress on plymouth boot splash | # Observe upgrade progress on plymouth boot splash | ||
# System reboots at end of upgrade | # System reboots at end of upgrade | ||
# <code>systemctl unmask packagekit-offline-update.service</code> | # <code>systemctl unmask packagekit-offline-update.service fwupd-offline-update.service</code> | ||
# That's about it | # That's about it | ||
(steps 2. and | (steps 2. and 7. are a temporary work-around, should be gone soon) | ||
== User Experience == | == User Experience == |
Revision as of 18:46, 27 July 2015
DNF System Upgrades
Summary
fedup is being redesigned and integrated into DNF.
Owner
- Name: Will Woods (fedup author)
- Email: wwoods@redhat.com
- Name: Zbigniew Jędrzejewski-Szmek (systemd developer)
- Email: zbyszek@in.waw.pl
- Name: Radek Holy (DNF developer)
- Email: rholy@redhat.com
- Release notes owner:
Current status
- Targeted release: Fedora 23
- Last updated: 2015-07-27
- Tracker bug: <will be assigned by the Wrangler>
Detailed Description
While fedup worked well in many circumstances, there were a lot of problems resulting from using upgrade.img
. This has caused nasty, hard-to-debug blocker bugs for every release since it was introduced.
It turns out that upgrade.img
was relying on some undocumented, unsupported systemd behavior.
After F22 this was discussed
on the systemd-devel mailing list, and the conclusion
was that fedup's boot behavior is broken by design, and systemd can't (and won't) continue to support it.
systemd already supports a simpler, more reliable method for performing Offline System Updates; the systemd team suggests using that to perform system upgrades.
Most of the remaining problems with fedup were caused by the fact that it was separate from the system packaging tools, and therefore had slight (and confusing) differences from the normal package update mechanisms.
Therefore, we propose that system upgrades should be handled by the system packaging tools, using systemd's Offline System Updates facility.
dnf-plugin-fedup is a proof-of-concept implementation; we propose to integrate support for this into DNF itself.
Benefit to Fedora
The upgrade process will be much more reliable, and well-integrated with the system packaging tools.
Better integration with system packaging tools:
- Upgrades support
distro-sync
mode - Systems do not need to (re-)download update metadata after the upgrade
We no longer need to build upgrade.img
, which saves space in boot/install media.
Scope
- Proposal owners:
- Make DNF able to send progress output to Plymouth (basically done; see dnf #281 and #313)
- Modify Offline System Updates spec as needed to support major system upgrades (in progress, see this systemd-devel thread)
- Support Offline System Updates in DNF (dnf-plugin-fedup does this, but it could be integrated into DNF itself)
- Add plugin to
dnf-plugins-core
ordnf
- Write man pages and other documentation
- Obsolete and retire fedup
- Other developers:
- Fix any conflicts with
packagekit-offline-update.service
- In the unlikely event that some kind of offline system migration is necessary (like UsrMove), it should be handled the same way as UsrMove - i.e. by a dracut script that runs the first time the new system boots after the upgrade.
- Fix any conflicts with
- Release engineering:
- Drop
upgrade.img
from image builds
- Drop
- Trademark approval: N/A (not needed for this Change)
Upgrade/compatibility impact
Existing systems can still use fedup to upgrade to F22, F21, and older.
If we backport the DNF changes (or provide them as plugins) we can even provide this as an alternate upgrade path from F21 (or earlier).
How To Test
NOTE: this will change as things evolve
- Install
dnf-plugin-fedup
- From git
- Or try the experimental package
dnf copr enable zbyszek/dnf-plugin-fedup
dnf install 'dnf-command(fedup)'
systemctl mask packagekit-offline-update.service fwupd-offline-update.service
dnf fedup download --releasever=23
- This should download lots of packages; it will probably also ask about importing the new GPG key.
dnf fedup reboot
- Observe upgrade progress on plymouth boot splash
- System reboots at end of upgrade
systemctl unmask packagekit-offline-update.service fwupd-offline-update.service
- That's about it
(steps 2. and 7. are a temporary work-around, should be gone soon)
User Experience
System upgrades will look a lot more like offline updates (because they're just big offline updates).
The commands to upgrade the system will probably be more like:
sudo dnf system-upgrade download --releasever=23 sudo dnf system-upgrade reboot
Dependencies
None known.
Contingency Plan
- Contingency mechanism: There are a few options; none of them are good.
- Find someone to maintain fedup and keep using it for one more release, even though upstream systemd says not to
- Use a different upgrade method for one release
- Just don't support upgrades for one release
- Contingency deadline: Beta, at latest - any of the above contingency plans would take a lot of work.
- Blocks release? Yes. Upgrades are a release criteria.
- Blocks product? Not product-specific AFAIK.
Documentation
systemd-devel discussion:
- http://lists.freedesktop.org/archives/systemd-devel/2015-March/029030.html
- http://lists.freedesktop.org/archives/systemd-devel/2015-April/031013.html
fedora devel announcement:
Offline System Updates spec:
Reference implementation:
DNF upstream (links to API docs etc.)
Release Notes
The fedup
utility has been retired; system upgrades are now handled by dnf system-upgrade
.