Misplaced Pages

Debian

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

This is an old revision of this page, as edited by Gronky (talk | contribs) at 12:20, 15 February 2008 (undo removal of "GNU/", per Jimbo's comment Portal_talk:Free_software#About_GNU.2FLinux_terminology). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Revision as of 12:20, 15 February 2008 by Gronky (talk | contribs) (undo removal of "GNU/", per Jimbo's comment Portal_talk:Free_software#About_GNU.2FLinux_terminology)(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff) Linux distribution
Debian GNU/Linux
Debian logo
Debian Etch's default GNOME desktop
DeveloperDebian Project
OS familyGNU/Linux
Working stateCurrent
Source modelFree and open source software
Initial release (1993-08-16) August 16, 1993 (age 31)
Latest release4.0r2 Etch / December 27, 2007 (2007-12-27)
Repository
Update methodAPT
Package managerdpkg
Platformsi386, AMD64, PowerPC, SPARC, DEC Alpha, ARM, MIPS, HPPA, S390, IA-64
Kernel typeMonolithic (Linux)
Default
user interface
GNOME, KDE & Xfce
Official websitehttp://www.debian.org

Debian (pronounced ) is a computer operating system composed entirely of free software. Its primary form, Debian GNU/Linux, is a popular and influential GNU/Linux distribution.

Debian is known for its adherence to the Unix and free software philosophies, and for its abundance of options — the current release includes over eighteen thousand software packages for eleven computer architectures, ranging from the ARM architecture commonly found in embedded systems and the IBM eServer zSeries mainframe architecture to the more common Intel x86 architecture found in modern personal computers. Debian GNU/Linux is the basis for several other distributions, including Knoppix, Linspire, MEPIS, sidux, Xandros, and the Ubuntu family. A university's study stated that Debian's 283 million source code lines would cost 10 billion USD to develop by conventional means.

Debian is also known for its package management system (especially APT), for its strict policies regarding its packages and the quality of its releases. These practices afford easy upgrades between releases and easy automated installation and removal of packages. Debian uses an open development and testing process. It is developed by volunteers from around the world and supported by donations through SPI, Inc., a non-profit umbrella organization for free software projects.

Debian's default install is very complete, providing the user with popular programs such as: OpenOffice, Iceweasel browser, Evolution mail, CD/DVD writing programs, music/video players, image viewers/editors, PDF viewers and many others. Only the first CD/DVD is necessary for the default install; the remaining discs contain all 18,000+ extra programs and packages currently available. If a user does not wish to download the CDs/DVDs, these extras can be downloaded separately using the package manager. Debian can also be configured to download and install updates automatically.

History

Debian was first announced on 16 August 1993 by Ian Murdock, then a student at Purdue University. Murdock initially called his system the "Debian Linux Release". Previously, Softlanding Linux System had been the first well-known attempt at making a GNU/Linux distribution from various software packages, and was a popular option among GNU/Linux users in 1994. It was the perceived poor maintenance and prevalence of bugs in SLS that motivated Murdock to launch a new distribution.

In the Debian Manifesto, Murdock called for the creation of a distribution to be maintained in an open manner, in the spirit of GNU/Linux. He formed the name "Debian" as a portmanteau of the first name of his girlfriend (now wife) Debra and his own first name. As such, Debian is pronounced as the corresponding syllables of these names in American English: /'dɛbiən/ but other pronunciations are common in different parts of the world.

The Debian Project grew slowly at first and released its first 0.9x versions in 1994 and 1995. The first ports to other architectures were begun in 1995, and the first 1.x version of Debian was released in 1996. In 1996, Bruce Perens replaced Ian Murdock as the project leader. In the same year, fellow developer Ean Schuessler suggested that Debian establish a social contract with its users. He distilled the resulting discussion on Debian mailing lists into the Debian Social Contract and the Debian Free Software Guidelines, defining fundamental commitments for the development of the distribution. He also initiated the creation of the legal umbrella organization Software in the Public Interest.

Perens left in 1998 before the release of the first glibc-based Debian, 2.0. The Project elected new leaders and made two more 2.x releases, each including more ports and packages. The Advanced Packaging Tool was deployed during this time and the first port to a non-Linux kernel, Debian GNU/Hurd, was started. The first GNU/Linux distributions based on Debian, Libranet, Corel Linux and Stormix's Storm Linux, were started in 1999. Though no longer developed, these distributions were the first of many distributions based on Debian.

In late 2000, the project made major changes to archive and release management, reorganizing software archive processes with new "package pools" and creating a testing branch as an ongoing, relatively stable staging area for the next release. Also in that year, developers began holding an annual conference called DebConf with talks and workshops for developers and technical users.

On April 8 2007 the project announced the official release of Debian GNU/Linux version 4.0, codenamed "Etch".

Development procedures

Software packages in development are either uploaded to the project branch named unstable, also known as sid, or the experimental branch. Software packages uploaded to unstable are normally versions stable enough to be released by the original upstream developer, but with the added Debian-specific packaging and other modifications introduced by Debian developers. These additions may be new and untested. Software not ready yet for the unstable branch is typically placed in the experimental branch.

After a version of a software package has remained in unstable for a certain length of time (depending on the urgency of the software's changes), that package is automatically migrated to the testing branch. The package's migration to testing occurs only if no serious (release-critical) bugs in the package are reported and if other software needed for package functionality qualifies for inclusion in testing.

Since updates to Debian software packages between official releases do not contain new features, some choose to use the testing and unstable branches for their newer packages. However, these branches are less tested than stable, and unstable doesn't receive timely security updates. Starting September 9, 2005 a testing security team provides security updates. In particular, incautious upgrades to working unstable packages can sometimes seriously break software functionality.

After the packages in testing have matured and the goals for the next release are met, the testing branch becomes the next stable release. The latest stable release of Debian (etch) is 4.0. It was released on April 8, 2007.

The forthcoming version is codenamed "lenny."

Project organization

Diagram of the organizational structure of the Project

The Debian Project is a volunteer organization with three foundational documents:

  • The Debian Social Contract defines a set of basic principles by which the project and its developers conduct affairs.
  • The Debian Free Software Guidelines define the criteria for "free software" and thus what software is permissible in the distribution, as referenced in the Social Contract. These guidelines have also been adopted as the basis of the Open Source Definition. Although it can be considered a separate document for all practical purposes, it formally is part of the Social Contract.
  • The Debian Constitution describes the organizational structure for formal decision-making within the Project, and enumerates the powers and responsibilities of the Debian Project Leader, the Debian Project Secretary, and the Debian Developers generally.

Currently, the project includes more than a thousand developers. Each of them sustains some niche in the project, be it package maintenance, software documentation, maintaining the project infrastructure, quality assurance, or release coordination. Package maintainers have jurisdiction over their own packages, although packages are increasingly co-maintained. Other tasks are usually the domain of smaller, more collaborative groups of developers.

The project maintains official mailing lists and conferences for communication and coordination between developers. For issues with single packages or domains, a public bug tracking system is used by developers and end-users both. Informally, Internet Relay Chat channels (primarily on the OFTC and freenode networks) are used for communication among developers and users as well.

Together, the Developers may make binding general decisions by way of a General Resolution or election. All voting is conducted by Cloneproof Schwartz Sequential Dropping, a Condorcet method of voting. A Project Leader is elected once per year by a vote of the Developers; in April 2007, Sam Hocevar was voted into this position, succeeding Anthony Towns. The Debian Project Leader has several special powers, but this power is far from absolute and is rarely utilized. Under a General Resolution, the Developers may, among other things, recall the leader, reverse a decision by him or his delegates, and amend the constitution and other foundational documents.

The Leader sometimes delegates authority to other developers in order for them to perform specialized tasks. Generally this means that a leader delegates someone to start a new group for a new task, and gradually a team gets formed that carries on doing the work and regularly expands or reduces their ranks as they think is best and as the circumstances allow.

A role in Debian with a similar importance to the Project Leader's is Release Manager. Release Managers set goals for the next release, supervise the process, and make the final decision as to when to release.

A list of many important positions in the Debian project is available at the Debian organization web page.

Developer recruitment, motivation, and resignation

The Debian project has a steady influx of applicants wishing to become developers. These applicants must undergo an elaborate vetting process which establishes their identity, motivation, understanding of the project's goals (embodied in the Social Contract), and technical competence. More information on the "New Maintainer" process is available at the Debian New Maintainer page.

Debian Developers join the Project for any number of reasons; some that have been cited in the past include:

  • a desire to contribute back to the Free Software community (practically all applicants are users of Free Software);
  • a desire to see some specific software task accomplished (some view the Debian user community as a valuable testing or proving ground for new software);
  • a desire to make, or keep, Free Software competitive with proprietary alternatives;
  • a desire to work closely with people that share some of their aptitudes, interests, and goals (there is a very strong sense of community within the Debian project which some applicants do not experience in their paid jobs);
  • a simple enjoyment of the iterative process of software development and maintenance.

Debian Developers may resign their positions at any time by orphaning the packages they were responsible for and sending a notice to the developers and the keyring maintainer (so that their upload authorization can be revoked).

Package life cycle

Flowchart of the life cycle of a Debian package

Each Debian software package has a maintainer who keeps track of releases by the "upstream" authors of the software and ensures that the package is compliant with Debian Policy, coheres with the rest of the distribution, and meets the standards of quality of Debian. In relations with users and other developers, the maintainer uses the bug tracking system to follow up on bug reports and fix bugs. Typically, there is only one maintainer for a single package, but increasingly small teams of developers "co-maintain" larger and more complex packages and groups of packages.

Periodically, a package maintainer makes a release of a package by uploading it to the "incoming" directory of the Debian package archive (or an "upload queue" which periodically batch-transmits packages to the incoming directory). Package uploads are automatically processed to ensure that they are well-formed (all the requisite files are in place) and that the package is digitally signed by a Debian developer using OpenPGP-compatible software. All Debian developers have public keys. Packages are signed to be able to reject uploads from hostile outsiders to the project, and to permit accountability in the event that a package contains a serious bug, a violation of policy, or malicious code.

If the package in incoming is found to be validly signed and well-formed, it is installed into the archive into an area called the "pool" and distributed every day to hundreds of mirrors worldwide. Initially, all package uploads accepted into the archive are only available in the "unstable" suite of packages, which contains the most up-to-date version of each package.

However, new code is also untried code, and those packages are only distributed with clear disclaimers. For packages to become candidates for the next "stable" release of the Debian distribution, they first need to be included in the "testing" suite. The requirements for a package to be included in "testing" is that it:

  • must have been in unstable for the appropriate length of time (the exact duration depends on the "urgency" of the upload).
  • must not have a greater number of "release-critical" bugs filed against it than the current version in testing. Release-critical bugs are those bugs which are considered serious enough that they make the package unsuitable for release.
  • must be compiled for all release architectures the package claims to support (eg: the i386-specific package gmod can be included in "testing").
  • must be a package for an architecture that is slated to release (in other words, packages for architectures that aren't scheduled to release with all the rest are never considered for "testing").
  • must not depend on versions of any packages that do not meet the above conditions.
APT shown on Debian Sarge

Thus, a release-critical bug in a package on which many packages depend, such as a shared library, may prevent many packages from entering the "testing" area, because that library is considered deficient.

Periodically, the Release Manager publishes guidelines to the developers in order to ready the release, and in accordance with them eventually decides to make a release. This occurs when all important software is reasonably up-to-date in the release-candidate suite for all architectures for which a release is planned, and when any other goals set by the Release Manager have been met. At that time, all packages in the release-candidate suite ("testing") become part of the released suite ("stable").

It is possible for a package -- particularly an old, stable, and seldom-updated one -- to belong to more than one suite at the same time. The suites are simply collections of pointers into the package "pool" mentioned above.

Releases

Graph of release dates, updates, and security support

As of April 2007, the latest stable release is version 4.0, code name etch. When a new version is released, the previous stable is labeled oldstable; currently, this is version 3.1, code name sarge.

In addition, a stable release gets minor updates (called point releases) marked, for example, like 3.1r1.

The Debian security team releases security updates for the latest stable major release, as well as for the previous stable release for one year. As version 4.0 Etch was released on 8 April 2007, this means that the security team expects to support version 3.1 Sarge until April 2008. For most uses it is strongly recommended to run a system which receives security updates. The testing version also receives security updates.

Debian has made nine major stable releases:

Version Code name Release date Archs Packages Currently supported by the Debian Security team Notes
1.1 buzz 17 June 1996 1 474 No dpkg, ELF transition, Linux 2.0
1.2 rex 12 December 1996 1 848 No -
1.3 bo 5 June 1997 1 974 No -
2.0 hamm 24 July 1998 2 ~ 1500 No glibc transition, new architecture: m68k
2.1 slink 9 March 1999 4 ~ 2250 No APT, new architectures: alpha, sparc
2.2 potato 15 August 2000 6 ~ 3900 No New architectures: arm, powerpc
3.0 woody 19 July 2002 11 ~ 8500 No New architectures: hppa, ia64, mips, mipsel, s390
3.1 sarge 6 June 2005 11 ~ 15400 Until approximately April 2008. Modular installer, semi-official amd64 support
4.0 etch 8 April 2007 11 ~ 18000 Until approximately one year after lenny is released, i.e. currently until September 2009. Graphical installer, udev transition, modular X.Org transition, new architecture: amd64, dropped architecture: m68k
TBA lenny Planned for September 2008 TBA TBA Until approximately one year after the following stable release. 32-bit SPARC architecture dropped. New Debian GNU/kFreeBSD port. Almost complete UTF8 support.

Due to an incident involving a CD vendor who made an unofficial and broken release labeled 1.0, an official 1.0 release was never made.

The code names of Debian releases are names of characters from the film Toy Story. The unstable, development distribution is nicknamed sid, after the emotionally unstable next-door neighbour boy who regularly destroyed toys.

Ports

Architectures

As of the current stable release, the official ports are:

The m68k port was the second official port in Debian, and has been part of five stable Debian releases. Due to its failure to meet the release criteria, it has been dropped before the release of etch. Still, it continues to be available as part of the unstable distribution:

Ongoing efforts include ports to Hitachi SuperH and Renesas M32R architectures, big-endian ARM port (armeb), little-endian EABI ARM port (armel), and 64-bit-only PowerPC port (ppc64).

Kernels

Further information: GNU variants

The Project describes itself as creating a "Universal Operating System" and several ports of all userland software to various operating system kernels are under development:

Although these are official Debian projects, there have been no official releases of the non-Linux ports yet, so currently Debian is exclusively a GNU/Linux distribution.

Desktop environments

Debian's current release offers three different official CD1s, one for each major desktop environment: GNOME, the default desktop environment, along with KDE and Xfce as alternatives.

Volatile updates, backports & Debian Testing

The Debian Project has rigorous requirements for software to be considered free. This is why not all software and documentation is available in the official Debian software repository. For example, documents using the GNU Free Documentation License with sections that the author does not permit to be altered or removed are considered non-free by Debian. Conversely, some in the free software community have criticized the Debian Project for making the non-free section available, rather than excluding proprietary software entirely. Also, Debian has in the past included proprietary device driver code (firmware) in its Linux kernel packages due to disagreement about whether Debian software guidelines extended to firmware for hardware components.

The stable release goes through a rigorous release cycle, so the system and packages are very stable. But the rigorous release cycles can take time, so a technical criticism of Debian is that the released stable branch can sometimes become too old for users' tastes. Almost three years elapsed between Debian 3.0 and Debian 3.1, and Debian 4.0 was announced for December 2006 (18 months after the release of 3.1) but released on April 8 2007.

These "criticisms" are countered to some degree by the existence of volatile updates, backports and Debian testing. The volatile project contains updates to the stable release for programs whose functionality requires frequent updates. Repositories of backported packages contain updated package versions compiled in the stable environment. Examples are backports.org and apt-get.org. Their use requires precise configuration of the priority of the packages repositories to be merged, done in the /etc/apt/preferences file. Otherwise these packages may be less integrated into the system, and may cause problems upgrading or conflicts between backported packages from different sources. The testing branch of Debian is much more stable than its name might indicate. It receives frequent package updates, without most of the drawbacks of using the unstable branch.

Thus the stable branch together with the backports.org repository is most suitable for users and servers which need stability but not the latest versions of software. Testing is recommended for users who like to live "on the bleeding edge", with updates and corrections released very frequently (sometimes every week). The unstable branch is for Debian developers who participate in a project and need the latest libraries available. There is one distribution based on Debian unstable / sid called sidux.

See also

Notes

  1. Linux Distributions - Facts and Figures
  2. Amor, Juan José (17 June 2007). "Measuring Etch: the size of Debian 4.0" (PDF). Retrieved 2007-09-16. {{cite web}}: Check date values in: |date= (help); Unknown parameter |coauthors= ignored (|author= suggested) (help)
  3. Murdock, Ian A (16 August 1993). "New release under development; suggestions requested". Newsgroupcomp.os.linux.development. CBusDD.MIK@unix.portal.com. {{cite newsgroup}}: Check date values in: |date= (help)
  4. Hillesley, Richard (5 November 2007). "Debian and the grass roots of Linux". {{cite web}}: Check date values in: |date= (help)
  5. Murdock, Ian A (16 August 1993). "NNTP Subject: New release under development; suggestions requested". Retrieved 2007-08-17. {{cite web}}: Check date values in: |date= (help)
  6. "About Debian".
  7. The Debian Systeme Martin F. Krafft p31
  8. Debian Documentation Team. A Brief History of Debian.
  9. "Debian security FAQ". 2007-02-28. Retrieved 2007-04-20. Q: How is security handled for testing and unstable? / A: The short answer is: it's not. {{cite web}}: Check date values in: |date= (help)
  10. Hess, Joey (2005-09-05). "announcing the beginning of security support for testing". debian-devel-announce (Mailing list). Retrieved 2007-04-20. {{cite mailing list}}: Check date values in: |date= (help); Unknown parameter |mailinglist= ignored (|mailing-list= suggested) (help)
  11. Debian testing security team
  12. "Debian Developer Reference". Retrieved 2007-08-09.
  13. Debian - Details of package gmod in lenny
  14. "Debian Releases". Retrieved 2007-05-22.
  15. ^ Debian security FAQ: Lifespan
  16. Debian testing security team
  17. "A Brief History of Debian: Debian Releases".
  18. "A Brief History of Debian, 4.2: the 1.x Releases". 2007-04-03. Retrieved 2007-04-26. 1.1 Buzz released June 1996 (474 packages, 2.0 kernel, fully ELF, dpkg) {{cite web}}: Check date values in: |date= (help)
  19. "A Brief History of Debian, 4.3: the 2.x Releases". 2007-04-03. Retrieved 2007-04-26. Debian 2.0 (Hamm) was released July 1998 for the Intel i386 and Motorola 68000 series architectures. This release marked the move to a new version of the system C libraries (glibc2 or for historical reasons libc6). {{cite web}}: Check date values in: |date= (help)
  20. "A Brief History of Debian, 4.3: the 2.x Releases". 2007-04-03. Retrieved 2007-04-26. this release of Debian was the first to require 2 CD-ROMs for the "Official Debian CD set" {{cite web}}: Check date values in: |date= (help)
  21. Martin Schulze (2000-08-15). "Debian GNU/Linux 2.2, the "Joel 'Espy' Klecker" release". debian-announce (Mailing list). {{cite mailing list}}: Check date values in: |date= (help); Unknown parameter |mailinglist= ignored (|mailing-list= suggested) (help)
  22. "A Brief History of Debian, 4.4: the 3.x Releases". 2007-04-03. Retrieved 2007-04-26. This is the first release including HP PA-RISC, IA-64, MIPS, MIPS (DEC) and IBM s/390 ports. {{cite web}}: Check date values in: |date= (help)
  23. Alexander Schmehl (2007-04-08). "Debian GNU/Linux 4.0 released". debian-announce (Mailing list). {{cite mailing list}}: Check date values in: |date= (help); Unknown parameter |mailinglist= ignored (|mailing-list= suggested) (help)
  24. Steve Langasek (2006-11-16). "testing d-i Release Candidate 1 and more release adjustments". debian-devel-announce (Mailing list). {{cite mailing list}}: Check date values in: |date= (help); Unknown parameter |mailinglist= ignored (|mailing-list= suggested) (help)
  25. ^ release update: release team, blockers, architectures, schedule, goals
  26. "A Brief History of Debian, 4.1: the 0.x Releases". 2007-04-03. Retrieved 2007-05-24. Debian 1.0, which was actually released as Debian 1.1 to avoid confusion after a CDROM manufacturer mistakenly labelled an unreleased version as Debian 1.0. {{cite web}}: Check date values in: |date= (help)
  27. "The Debian GNU/Linux FAQ - The Debian FTP archives". Retrieved 2007-05-24.
  28. "Debian Ports". Retrieved 2007-05-25.
  29. "Debian -- Ports" (Webpage). Webpage. Debian Foundation. 28. Retrieved 2007-08-10. {{cite web}}: Check date values in: |date= and |year= / |date= mismatch (help); Unknown parameter |month= ignored (help)
  30. General Resolution: Why the GNU Free Documentation License is not suitable for Debian main.
  31. "Upcoming release".
  32. The debian-volatile Project

References

External links

Debian
Software in the Public Interest
General Debian OpenLogo
People
Derivatives
Kernels
Forks
Software
OthersDebian–Mozilla trademark dispute
Linux distributions
Android
LineageOS
Other
Arch
Debian
Ubuntu
Other
Fedora
CentOS Stream
Other
Gentoo
Mandrake
Mandriva
Slackware
SUSE
Other
Discontinued
Android
Arch
Debian
Gentoo
Red Hat/Fedora
Slackware
SUSE
Other
Categories: