Table of Contents
There are many different Debian distributions. Choosing the proper Debian distribution is an important decision. This section covers some information useful for users that want to make the choice best suited for their system and also answers possible questions that might be arising during the process. It does not deal with "why you should choose Debian" but rather "which distribution of Debian".
For more information on the available distributions read Section 6.1, “How many Debian distributions are there?”.
The answer is a bit complicated. It really depends on what you intend to do. One solution would be to ask a friend who runs Debian. But that does not mean that you cannot make an independent decision. In fact, you should be able to decide once you complete reading this chapter.
If security or stability are at all important for you: install stable. period. This is the most preferred way.
If you are a new user installing to a desktop machine, start with stable. Some of the software is quite old, but it's the least buggy environment to work in. You can easily switch to the more modern unstable (or testing) once you are a little more confident.
If you are a desktop user with a lot of experience in the operating system and do not mind facing the odd bug now and then, or even full system breakage, use unstable. It has all the latest and greatest software, and bugs are usually fixed swiftly.
If you are running a server, especially one that has strong stability requirements or is exposed to the Internet, install stable. This is by far the strongest and safest choice.
The following questions (hopefully) provide more detail on these choices. After reading this whole FAQ, if you still could not make a decision, stick with the stable distribution.
Try to search the web using a search engine and see if someone else is able to get it working in stable. Most of the hardware should work fine with stable. But if you have some state-of-the-art, cutting edge hardware, it might not work with stable. If this is the case, you might want to install/upgrade to either testing or unstable.
For laptops, https://www.linux-on-laptops.com/ is a very good website to see if someone else is able to get it to work under Linux. The website is not specific to Debian, but is nevertheless a tremendous resource. I am not aware of any such website for desktops.
Another option would be to ask in the debian-user mailing list by sending an email to debian-user@lists.debian.org. Messages can be posted to the list even without subscribing. The archives can be read through https://lists.debian.org/debian-user/. Information regarding subscribing to the list can be found at the location of archives. You are strongly encouraged to post your questions on the mailing-list rather than on irc. The mailing-list messages are archived, so the solution to your problem can help others with the same issue.
Yes. Unstable has the most recent (latest) versions. But the packages in unstable are not well tested and might have bugs.
On the other hand, stable contains old versions of packages. But this package is well tested and is less likely to have any bugs.
The packages in testing fall between these two extremes.
Well, you might be correct. The age of the packages at stable depends on when the last release was made. Since there is typically over 1 year between releases you might find that stable contains old versions of packages. However, they have been tested in and out. One can confidently say that the packages do not have any known severe bugs, security holes etc., in them. The packages in stable integrate seamlessly with other stable packages. These characteristics are very important for production servers which have to work 24 hours a day, 7 days a week.
On the other hand, packages in testing or unstable can have hidden bugs, security holes etc. Moreover, some packages in testing and unstable might not be working as intended. Usually people working on a single desktop prefer having the latest and most modern set of packages. Unstable is the solution for this group of people.
As you can see, stability and novelty are two opposing ends of the spectrum. If stability is required: install stable distribution. If you want to work with the latest packages, then install unstable.
Yes, but it is a one way process. You can go from stable --> testing --> unstable. But the reverse direction is not "possible". So better be sure if you are planning to install/upgrade to unstable.
Actually, if you are an expert and if you are willing to spend some time and if you are real careful and if you know what you are doing, then it might be possible to go from unstable to testing and then to stable. The installer scripts are not designed to do that. So in the process, your configuration files might be lost and...
No. This is a rather subjective issue. There is no perfect answer as it depends on your software needs, your willingness to deal with possible breakage, and your experience in system administration. Here are some tips:
Stable is rock solid. It does not break and has full security support. But it not might have support for the latest hardware.
Testing has more up-to-date software than Stable, and it breaks less often than Unstable. But when it breaks, it might take a long time for things to get rectified. Sometimes this could be days and it could be months at times. It also does not have permanent security support.
Unstable has the latest software and changes a lot. Consequently, it can break at any point. However, fixes get rectified in many occasions in a couple of days and it always has the latest releases of software packaged for Debian.
When deciding between testing and unstable bear in mind that there might be
times when tracking testing would be beneficial as opposed to unstable. One of
this document's authors experienced such situation due to the gcc transition
from gcc3 to gcc4. He was trying to install the labplot
package on a machine tracking unstable and
it could not be installed in unstable as some of its dependencies have
undergone gcc4 transition and some have not. But the package in testing was
installable on a testing machine as the gcc4 transitioned packages had not
"trickled down" to testing.
Sometimes, a package might not be installable through package management tools. Sometimes, a package might not be available at all, maybe it was (temporarily) removed due to bugs or unmet dependencies. Sometimes, a package installs but does not behave in the proper way.
When these things happen, the distribution is said to be broken (at least for this package).
The bug fixes and improvements introduced in the unstable distribution trickle down to testing after a certain number of days. Let's say this threshold is 5 days. The packages in unstable go into testing only when there are no RC-bugs reported against them. If there is a RC-bug filed against a package in unstable, it will not go into testing after the 5 days.
The idea is that, if the package has any problems, it would be discovered by people using unstable and will be fixed before it enters testing. This keeps testing in a usable state for most of the time. Overall a brilliant concept, if you ask me. But things aren't always that simple. Consider the following situation:
Imagine you are interested in package XYZ.
Let's assume that on June 10, the version in testing is XYZ-3.6 and in unstable it is XYZ-3.7.
After 5 days, XYZ-3.7 from unstable migrates into testing.
So on June 15, both testing and unstable have XYZ-3.7 in their repositories.
Let's say, the user of testing distribution sees that a new XYZ package is available and updates the XYZ-3.6 to XYZ-3.7.
Now on June 25, someone using testing or unstable discovers an RC bug in XYZ-3.7 and files it in the BTS.
The maintainer of XYZ fixes this bug and uploads it to unstable say on June 30. Here it is assumed that it takes 5 days for the maintainer to fix the bug and upload the new version. The number 5 should not be taken literally. It could be less or more, depending upon the severity of the RC-bug at hand.
This new version in unstable, XYZ-3.8 is scheduled to enter testing on July 5th.
But on July 3rd some other person discovers another RC-bug in XYZ-3.8.
Let's say the maintainer of XYZ fixes this new RC-bug and uploads new version of XYZ after 5 days.
So on July 8th, testing has XYZ-3.7 while unstable has XYZ-3.9.
This new version XYZ-3.9 is now rescheduled to enter testing on July 13th.
Now since you are running testing, and since XYZ-3.7 is buggy, you could probably use XYZ only after July 13th. That is you essentially ended up with a broken XYZ for about one month.
The situation can get much more complicated, if say, XYZ depends on 4 other packages. This could in turn lead to an unusable testing distribution for months. While the scenario above is immaginary, similar things can occur in real life, though they are rare.
One of the main reasons why many people choose Debian over other Linux distributions is that it requires very little administration. People want a system that just works. In general one can say that stable requires very little maintenance, while testing and unstable require constant maintenance from the administrator. If you are running stable, all you need to worry about is keeping track of security updates. If you are running either testing or unstable it is a good idea to be aware of the new bugs discovered in the installed packages, new bugfixes/features introduced etc.
This question will not help you in choosing a Debian distribution. But sooner or later you will face this question.
The stable distribution is currently bullseye; The next stable distribution will be called bookworm. Let's consider the particular case of what happens when bookworm is released as the new stable version.
oldstable = buster; stable = bullseye; testing = bookworm; unstable = sid
Unstable is always referred to as sid irrespective of whether a release is made or not.
Packages constantly migrate from sid to testing (i.e. bookworm). But packages in stable (i.e. bullseye) remain the same except for security updates.
After some time testing becomes frozen. But it will still be called testing. At this point no new packages from unstable can migrate to testing unless they include release-critical (RC) bug fixes.
When testing is frozen, all the new bugfixes introduced have to be manually checked by the members of the release team. This is done to ensure that there won't be any unknown severe problems in the frozen testing.
RC bugs in 'frozen testing' are reduced to either zero or, if greater than zero, the bugs are either marked as ignored for the release or are deferred for a point release.
The 'frozen testing' with no rc-bugs will be released as the new stable version. In our example, this new stable release will be called bookworm.
At this stage oldstable = bullseye, stable = bookworm. The contents of stable and 'frozen testing' are same at this point.
A new testing is based on the old testing.
Packages start coming down from sid to testing and the Debian community will be working towards making the next stable release.
In most situations it is very easy to figure this out. Take a look at the
/etc/apt/sources.list
file. There will be an entry
similar to this:
deb http://ftp.us.debian.org/debian/ unstable main contrib
The third field ('unstable' in the above example) indicates the Debian distribution the system is currently tracking.
You can also use lsb_release (available in the lsb-release
package). If you run this program in
an unstable system you will get:
$ lsb_release -a LSB Version: core-2.0-noarch:core-3.0-noarch:core-3.1-noarch:core-2.0-ia32:core-3.0-ia32:core-3.1-ia32 Distributor ID: Debian Description: Debian GNU/Linux unstable (sid) Release: unstable Codename: sid
However, this is not always that easy. Some systems might have
sources.list
files with multiple entries corresponding to
different distributions. This could happen if the administrator is tracking
different packages from different Debian distributions. This is frequently
referred to as apt-pinning. These systems might run a mixture of
distributions.
If you are currently running stable, then in the
/etc/apt/sources.list
file the third field will be either
'bullseye' or 'stable'. You need to change this to the distribution you want to
run. If you want to run testing, then change the third field of
/etc/apt/sources.list
to 'testing'. If you want to run
unstable, then change the third field to 'unstable'.
Currently testing is called bookworm. So, if you change the third field of
/etc/apt/sources.list
to 'bookworm', then also you will be
running testing. But even when bookworm becomes stable, you will still be
tracking bookworm.
Unstable is always called Sid. So if you change the third field of
/etc/apt/sources.list
to 'sid', then you will be tracking
unstable.
Currently Debian offers security updates for testing but not for unstable, as
fixes in unstable are directly made to the main archive. So if you are running
unstable make sure that you remove the lines relating to security updates in
/etc/apt/sources.list
.
If there is a release notes document available for the distribution you are upgrading to (even though it has not yet been released) it would be wise to review it, as it might provide information on how you should upgrade to it.
Nevertheless, once you make the above changes, you can run aptitude
update
and then install the packages that you want. Notice that
installing a package from a different distribution might automatically upgrade
half of your system. If you install individual packages you will end up with a
system running mixed distributions.
It might be best in some situations to just fully upgrade to the new distribution running apt full-upgrade, aptitude safe-upgrade or aptitude full-upgrade. Read apt's and aptitude's manual pages for more information.
It depends on the entries in the /etc/apt/sources.list
file. If you are currently tracking testing, these entries are similar to
either:
deb http://ftp.us.debian.org/debian/ testing main
or
deb http://ftp.us.debian.org/debian/ bookworm main
If the third field in /etc/apt/sources.list
is 'testing'
then you will be tracking testing even after a release is made. So after
bookworm is released, you will be running a new Debian distribution which will
have a different codename. Changes might not be apparent at first but will be
evident as soon as new packages from unstable go over to the testing
distribution.
But if the third field contains 'bookworm' then you will be tracking stable (since bookworm will then be the new stable distribution).
They are not Debian; they are Debian based. Though there are many similarities and commonalities between them, there are also crucial differences.
All these distributions have their own merits and are suited to some specific set of users. For more information, read Software distributions based on Debian available at the Debian website.
These distributions are Debian based. But they are not Debian. You will be
still able to use apt package tools by pointing the
/etc/apt/sources.list
file to these distributions'
repositories. But then you are not running Debian, you are running a different
distribution. They are not the same.
In most situations if you stick with one distribution you should use that and not mix packages from other distributions. Many common breakages arise due to people running a distribution and trying to install Debian packages from other distributions. The fact that they use the same formatting and name (.deb), does not make them immediately compatible.
For example, Knoppix is a Linux distribution designed to be booted as a live CD whereas Debian is designed to be installed on the hard-disk. Knoppix is great if you want to know whether a particular piece of hardware works, or if you want to experience how a GNU/Linux system 'feels' etc., Knoppix is good for demonstration purposes while Debian is designed to run 24/7. Moreover the number of packages available, the number of architectures supported by Debian are far more than that of Knoppix.
If you want Debian, it is best to install Debian from the get-go. Although it is possible to install Debian through other distributions, such as Knoppix, the procedure calls for expertise. If you are reading this FAQ, I would assume that you are new to both Debian and Knoppix. In that case, save yourself a lot of trouble later and install Debian right at the beginning.
You are advised not to use the Debian forums (either mailing lists or IRC) for help as people there may base their suggestions on the assumption that you are running a Debian system. These "fixes" might not be suited to what you are running, and might even make your problem worse.
Use the forums of the specific distribution you are using first. If you do not get help or the help you get does not fix your problem you might want to try asking in Debian forums, but keep the advice of the previous paragraph in mind.
Consider the change from a Debian-based distribution to Debian just like a change from one operating system to another one. You should make a backup of all your data and reinstall the operating system from scratch. You should not attempt to "upgrade" to Debian using the package management tools as you might end up with an unusable system.
If all your user data (i.e. your /home
) is under a
separate partition migrating to Debian is actually quite simple, you just have
to tell the installation system to mount (but not reformat) that partition when
reinstalling. Making backups of your data, as well as your previous system's
configuration (i.e. /etc/
and, maybe,
/var/
) is still encouraged.