From Fedora Project Wiki
(Add deliverables)
(Add releng issue)
Line 58: Line 58:
* Other developers: Fedora Infrastructure needs to start creating zchunked metadata
* Other developers: Fedora Infrastructure needs to start creating zchunked metadata


* Release engineering: [https://pagure.io/releng/issues #Releng issue number] (a check of an impact with Release Engineering is needed) <!-- REQUIRED FOR SYSTEM WIDE AS WELL AS FOR SELF CONTAINED CHANGES -->
* Release engineering: [https://pagure.io/releng/issue/7600 #7600]
<!-- Does this feature require coordination with release engineering (e.g. changes to installer image generation or update package delivery)?  Is a mass rebuild required?  include a link to the releng issue.
The issue is required to be filed prior to feature submission, to ensure that someone is on board to do any process development work and testing, and that all changes make it into the pipeline; a bullet point in a change is not sufficient communication -->
** [[Fedora_Program_Management/ReleaseBlocking/Fedora{{FedoraVersionNumber|next}}|List of deliverables]]: Zchunk repository metadata
** [[Fedora_Program_Management/ReleaseBlocking/Fedora{{FedoraVersionNumber|next}}|List of deliverables]]: Zchunk repository metadata



Revision as of 12:44, 30 June 2018

Zchunk Metadata

Summary

All dnf repository metadata will be compressed with the zchunk format rather than xz or gzip.

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

  • Other developers: Fedora Infrastructure needs to start creating zchunked 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

TODO: Testing involves messing around with /var/cache/dnf

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

Release Notes