Ask Fedora
In this section, we answer general questions from Fedora community. Send your questions to askfedora AT fedoraproject.org and Fedora News Team will bring you answers from the Fedora Developers and Contributors to selected number of questions every week as part of our weekly news report. Please indicate if you do not wish your name and/or email address to be published.
http://fedoraproject.org/wiki/AskFedora
Standardized Package Format
Arthur Pemberton asked: "When are the big players in the Linux ecosystem going to converge on a single package system which is a superset of .deb and .rpm? This seems like something that needs to be done before this mostly unnecessary difference gets too ingrained to be changed."
Two reasons are usually given for converging on a single packaging standard. The first is to create packages that can be installed on many distributions without change; this is particularly attractive to third-party software vendors who wish to create a single repository of their software for use with a range of distributions rather than package and distribute their software within those distributions.
In order to support truly portable packages, it is necessary to standardize not only the package format, but the available libraries, library versions, file locations, utility commands, and system services. This is proved by the fact that, for example, Fedora and SUSE RPMs do not usually cleanly install on other distribution, despite using a common package format.
The Linux Standard Base (LSB)[1] project of The Linux Foundation[2]
has been working on such a system-wide standard for many years, walking the fine line between standardizing too little (yielding an ineffective standard) and standardizing too much (leaving little room for differentiation between distributions). The work of LSB has been internationally recognized as ISO/IEC 23360, and Fedora conforms to the LSB.
In terms of packaging, LSB mandates support for a restricted version of RPM[3], without triggers and with restrictions on the content and execution-order requirements of scriptlets[4]. These restrictions ensure that LSB-compliant RPMs can be successfully processed by conversion tools such as Debian's "alien" command. However, as its name implies, the LSB defines only a base for a distribution, and many of a distribution's packages need to take advantage of a broader feature set than provided for by the LSB. This need is expressed in the more advanced features provided by the full RPM and DEB package specifications.
It should be noted that a number of package systems have been developed which attempt to address cross-distribution packaging issues, including Autopackage[5], ZeroInstall[6], and Klik[7] (ZeroInstall and Klik also enabling user-level package installation) -- but these have not gain widespread support.
The second advantage to a standard package format is a reduction in the duplication of labour by each distribution, especially if packaging information (such as a basic RPM .spec file) is provided by the upstream software source. However, packaging standards, security configuration (such as SELinux policy), and naming conventions vary so significantly between distributions that extensive customization of the package is usually required, greatly reducing the value of distributing standard package information.
The existence of multiple linux distributions fuels a productive competitiveness which spurs innovation. As long as multiple distributions thrive, multiple package formats are likely to remain in use.
- ↑ http://www.linuxfoundation.org/en/LSB
- ↑ http://www.linuxfoundation.org/
- ↑ http://refspecs.freestandards.org/LSB_3.1.0/LSB-Core-generic/LSB-Core-generic/packagefmt.html
- ↑ http://refspecs.freestandards.org/LSB_3.1.0/LSB-Core-generic/LSB-Core-generic/pkgscripts.html
- ↑ http://autopackage.org/
- ↑ http://zero-install.sourceforge.net/
- ↑ http://klik.atekon.de/