(Add releng issue) |
(Create test cases) |
||
Line 74: | Line 74: | ||
A good "how to test" should answer these four questions: | A good "how to test" should answer these four questions: | ||
nowiki | |||
0. What special hardware / data / etc. is needed (if any)? | 0. What special hardware / data / etc. is needed (if any)? | ||
1. How do I prepare my system to test this change? What packages | 1. How do I prepare my system to test this change? What packages | ||
Line 83: | Line 83: | ||
--> | --> | ||
' | Check that zchunk metadata is being downloaded: | ||
# Remove /var/cache/dnf/* | |||
# Run dnf update | |||
# Check that the files in /var/cache/dnf/updates-*/repodata have .zck extensions | |||
Check that zchunk metadata won't be redownloaded when it matches the current metadata: | |||
# Remove /var/cache/dnf/updates-*/repodata/repomd.xml | |||
# Run dnf update | |||
# Check that the repodata download size matches the size of ''just'' repomd.xml | |||
Check that only different chunks are being downloaded:<br/> | |||
''Todo: setup two snapshots of updates that are a few days apart'' | |||
# Create /etc/yum.repos.d/test.repo that contains the following lines: | |||
#:[test] | |||
#:name=Fedora $releasever - $basearch - Test | |||
#:failovermethod=priority | |||
#:baseurl=first_snapshot_from_todo | |||
#:enabled=0 | |||
#:gpgcheck=0 | |||
#:skip_if_unavailable=True | |||
#: | |||
# Run dnf --enablerepo=test update | |||
# Change /etc/yum.repos.d/test.repo as follows: | |||
#: baseurl=second_snapshot_from_todo | |||
#: | |||
# Run dnf --enablerepo=test update | |||
# Check that the repodata download size matches ''delta size from todo'' bytes | |||
== User Experience == | == User Experience == |
Revision as of 13:05, 30 June 2018
Zchunk Metadata
Summary
All dnf repository metadata will be compressed with the zchunk format rather than xz or gzip.
Owner
- Name: Jonathan Dieter
- Email: jdieter@gmail.com
- Name: Neal Gompa
- Email: ngompa13@gmail.com
- Release notes owner:
Current status
- Targeted release: Fedora 29
- Last updated: 2018-06-30
- Tracker bug: <will be assigned by the Wrangler>
Detailed Description
Currently Fedora's repository metadata is compressed using the xz and gzip formats. Zchunk is a new compression format designed to allow for highly efficient deltas. When Fedora's metadata is compressed using zchunk, dnf will download only the differences between any earlier copies of the metadata and the current version.
Benefit to Fedora
Dnf and related tools will see significant reductions in the size of the metadata they download, especially if they are run on a regular basis.
Scope
- Proposal owners:
- Package zchunk for Fedora
- Get the pull requests to enable zchunk in dnf, libdnf, librepo, libsolv and createrepo_c merged upstream
- Create a new package for Fedora's zchunk dictionaries.
- Other developers: Fedora Infrastructure needs to start creating zchunked metadata
- Release engineering: #7600
- List of deliverables: Zchunk repository metadata
- Policies and guidelines: Packaging guidelines are not affected by this change.
- Trademark approval: N/A (not needed for this Change)
Upgrade/compatibility impact
Old-style xz and gzip metadata will continue to be generated by createrepo_c, so old versions of Fedora will use the xz/gzip metadata while upgrading to the new version, and then use the new zchunk metadata after the upgrade.
How To Test
Check that zchunk metadata is being downloaded:
- Remove /var/cache/dnf/*
- Run dnf update
- Check that the files in /var/cache/dnf/updates-*/repodata have .zck extensions
Check that zchunk metadata won't be redownloaded when it matches the current metadata:
- Remove /var/cache/dnf/updates-*/repodata/repomd.xml
- Run dnf update
- Check that the repodata download size matches the size of just repomd.xml
Check that only different chunks are being downloaded:
Todo: setup two snapshots of updates that are a few days apart
- Create /etc/yum.repos.d/test.repo that contains the following lines:
- [test]
- name=Fedora $releasever - $basearch - Test
- failovermethod=priority
- baseurl=first_snapshot_from_todo
- enabled=0
- gpgcheck=0
- skip_if_unavailable=True
- Run dnf --enablerepo=test update
- Change /etc/yum.repos.d/test.repo as follows:
- baseurl=second_snapshot_from_todo
- Run dnf --enablerepo=test update
- Check that the repodata download size matches delta size from todo bytes
User Experience
This change will allow Fedora users to see significant reductions in the size of the metadata they download. If they check for updates daily, they should see a savings of up to 95%.
Dependencies
Upstream needs to merge the zchunk pull requests, and Fedora 29's dnf, libdnf, librepo, libsolv and createrepo_c will need to pull the patches in.
Contingency Plan
- Contingency mechanism:
- If there are problems generating zchunked metadata, Fedora Infrastructure will need to disable zchunk metadata generation
- If there are problems downloading the zchunked metadata, we will make downloading zchunk metadata a manual option you must set in dnf.conf
- Contingency deadline: 2018-08-28 (Beta Freeze)
- Blocks release? No, as long as the contingency is enacted
- Blocks product? No
Documentation
Introduction to zchunk
What is zchunk and how does it work?
How to use the zchunk utilities
The zchunk file format