Line 52: | Line 52: | ||
* Fully integrated Modularity in LIBDNF workflows | * Fully integrated Modularity in LIBDNF workflows | ||
** Modularity is supported in DNF and LIBDNF but it is not fully integrated. Integration was not possible due to limitation of compatibility with other tools (PackageKit) | |||
** Fully integrated modularity requires changes in library workflow | |||
* Unified user interface | |||
** DNF/YUM was developed for decades with impact of multiple styles and naming conventions (options, configuration options, commands) | |||
* Plugins | |||
** DNF plugins are not applicable for PackageKit and Microdnf (e.g. versionlock, subscription-manager), therefore PackageKit behaves differently to DNF | |||
* New plugins (C++, Python) will be available for all users | |||
** unified behaviour | |||
** Removal of functional duplicates | |||
*** Decrease maintenance cost | |||
* Shared configurations | |||
** In DNF4 the configuration is only partially honored by PackageKit and Microdnf | |||
* New Daemon | |||
** The new daemon can provide an alternative to PackageKit for RPMs (only one backend of PackageKit) if it will be integrated into Desktop | |||
* Additional improvements | |||
** Reports in structure (API) | |||
*** DNF reports a lot of important information only in logs | |||
* Shared cache and improved cache handling (Optional, not available in Fedora 38) | |||
** Microdnf, DNF4, and PackageKit use cached repositories on a different location with different cache structure. | |||
* Performance improvement | |||
** Loading of repositories | |||
** Advisory operation | |||
** RPM query | |||
*** Name filters with a case-insensitive search | |||
** Smart sharing of metadata between dnf, microdnf, daemon | |||
*** Reduce disk and downloads requirements | |||
<!-- Expand on the summary, if appropriate. A couple sentences suffices to explain the goal, but the more details you can provide the better. --> | <!-- Expand on the summary, if appropriate. A couple sentences suffices to explain the goal, but the more details you can provide the better. --> | ||
Revision as of 11:46, 24 March 2022
Major update Of Microdnf
Summary
Major upgrade of Microdnf is the first step in evolution of package management in Fedora. The new microdnf has ambitions to provide all major features of DNF without loosing its minimal footprint.
Owner
- Name: Jaroslav Mracek
- Email: jmracek@redhat.com
Current status
- Targeted release: Fedora Linux 38
- Last updated: 2022-03-24
- FESCo issue: <will be assigned by the Wrangler>
- Tracker bug: <will be assigned by the Wrangler>
- Release notes tracker: <will be assigned by the Wrangler>
Detailed Description
The new major microdnf will provide huge improvements and even in some cases better behavior then DNF. In future the new microdnf will replace DNF. The new microdnf will be accompanied with a new library (libdnf5
) and new DNF Daemon.
LIBDNF5 features
- Fully integrated Modularity in LIBDNF workflows
- Modularity is supported in DNF and LIBDNF but it is not fully integrated. Integration was not possible due to limitation of compatibility with other tools (PackageKit)
- Fully integrated modularity requires changes in library workflow
- Unified user interface
- DNF/YUM was developed for decades with impact of multiple styles and naming conventions (options, configuration options, commands)
- Plugins
- DNF plugins are not applicable for PackageKit and Microdnf (e.g. versionlock, subscription-manager), therefore PackageKit behaves differently to DNF
- New plugins (C++, Python) will be available for all users
- unified behaviour
- Removal of functional duplicates
- Decrease maintenance cost
- Shared configurations
- In DNF4 the configuration is only partially honored by PackageKit and Microdnf
- New Daemon
- The new daemon can provide an alternative to PackageKit for RPMs (only one backend of PackageKit) if it will be integrated into Desktop
- Additional improvements
- Reports in structure (API)
- DNF reports a lot of important information only in logs
- Reports in structure (API)
- Shared cache and improved cache handling (Optional, not available in Fedora 38)
- Microdnf, DNF4, and PackageKit use cached repositories on a different location with different cache structure.
- Performance improvement
- Loading of repositories
- Advisory operation
- RPM query
- Name filters with a case-insensitive search
- Smart sharing of metadata between dnf, microdnf, daemon
- Reduce disk and downloads requirements
Feedback
Benefit to Fedora
Scope
- Proposal owners:
- Other developers:
- Release engineering: #Releng issue number
- Policies and guidelines: N/A (not needed for this Change)
- Trademark approval: N/A (not needed for this Change)
- Alignment with Objectives:
Upgrade/compatibility impact
How To Test
User Experience
Dependencies
Contingency Plan
- Contingency mechanism: (What to do? Who will do it?) N/A (not a System Wide Change)
- Contingency deadline: N/A (not a System Wide Change)
- Blocks release? N/A (not a System Wide Change), Yes/No
Documentation
N/A (not a System Wide Change)