Read this Debian FAQ . As it says, Debian comes in 3 distributions - stable, testing, unstable.
As of Jul 10, 2005 stable is called Sarge; testing is called Etch; unstable is popularly known as Sid.
They are not Debian; they are _Debian based_. Though there are many similarities and commonalities between them, there are also crucial differences.
Knoppix is Debian based. But it is not Debian. You will be able to use apt package tools by pointing the /etc/apt/sources.list file to the Knoppix repositories. But then you are not running Debian, you are running Knoppix. They are not the same.
Knoppix is a Linux distribution designed to be booted as a live CD where as Debian is designed to be installed on hard-disk. Knoppix is great if you want to know whether a particular hardware works, or if you want to experience how a 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 greater 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 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 should ask in the knoppix-mailing lists after searching through google. A list of knoppix related links can be found here. Asking in Debian forums will not be of any help. Remember "knoppix is not Debian" and now say that 10 times.
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 FAQ.
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 once you are a little more confident.
If you are a desktop user with some experience in Linux and does not mind facing the odd bug now and then, 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 requirements, 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 google around 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 unstable.
For laptops, http://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 http://lists.debian.org/debian-user/. Information regarding subscribing to the list can be found at the location of archives. I strongly encourage to post your questions on the mailing-list than on irc. The mailing-list messages are archived, so 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.
For example, The last time
I updated this document, the
different versions of the apt package in the various distributions are
as follows
stable --- 0.5.28.6
testing --- 0.5.28.6
unstable --- 0.6.38
Yes. You are in fact correct. Stable usually contains old versions of packages. But they have been tested in and out. One can confidently say that the packages do not have any 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.
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 ....This is a rather subjective issue. There is no perfect answer but only a "wise guess" could be made while deciding between unstable and testing. My personal order of preference is Stable, Unstable and Testing. The issue is like this:
Stable is rock solid. It does not break.
Testing breaks less often than Unstable. But when it breaks, it takes a long time for things to get rectified. Sometimes this could be days and it could be months at times. But in unstable things get rectified within couple of days.
But there are times when tracking testing would be beneficial as opposed to unstable. I encountered one such situation due to the gcc transition from gcc3 to gcc4. I was trying to install 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 is installable on a testing machine as the gcc4 transitioned packages have not "trickled down" to testing.
Sometimes, a package might not be installable through apt-get. Sometimes, a package might not be available at all. Sometimes, a package installs but does not behave in the proper way.
When these things happen, the distribution is said to be broken.
The bug fixes and improvements introduced in unstable distribution trickle down to testing after a certain number of days. Let's say this threshold is 10 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 10 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 the testing in an usable state for most period of the time. Overall a brilliant concept, if you ask me. But things are not so simple. Consider the following situation.
Situation:
One of the main reasons I chose Debian over other Linux distributions is that it requires very little administration. I wanted a system that just works. In general one can say that, stable requires very little maintenance while testing and Sid 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.,
The following pictures, from Matthew Exon, illustrate the maintenance trauma the various distribution options might cause you over time. The graph provides a qualitative (but not quantitative) picture of the amount of time administrators might be spending.
This question will not help you in choosing a Debian distribution. But sooner or later you will face this question. I included it here just because it has not been covered by any other FAQ.
As of Jul 10, 2005 the stable distribution is referred to as Sarge; The next stable distribution will be called as 'Etch'. Let's consider the particular case as to what happens when Etch is released as the new stable version.
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
deb http://ftp.us.debian.org/debian/ unstable main contrib non-free
The third field ('unstable' in the above example) tells about the Debian distribution you are currently tracking.
However, the story does not stop there. In some sources.list file, you might have 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. Apt-pinning is totally different ball game and I wont go into it in this document.
deb http://ftp.us.debian.org/debian/ testing main contrib non-freeor
deb http://ftp.us.debian.org/debian/ etch main contrib non-free
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 etch is released, you will be running ABCDEFG ( where ABCDEFG will be the name of new testing distribution ).
But if the third field contains 'etch' then you will be tracking stable (since etch will then be the new stable distribution).
The network install images for stable (sarge) can be found at http://www.debian.org/CD/netinst/
The network install images for testing (etch) can be found at http://www.debian.org/devel/debian-installer/
There are no network install images for unstable. If you want to install unstable, download the image for testing and upgrade to unstable by changing /etc/apt/sources.list
I run unstable (sid) on my desktop. I am interested in laying out my hands on the cutting edge software. If there is a new version of firefox out there, I would like to try it out immediately without worrying about any bugs/security holes etc. That is why I chose unstable.
But if you are running a server (for example, with web, FTP or CVS servers) where security is of utmost importance, it is strongly advised to stick to stable.
Oh yeah. Too many to list here. Read the debian-user mailing list archive and you know what I am talking about. The archives of the debian-user mailing list can be found at http://lists.debian.org/debian-user/
The best bet would be stable distribution.
Great! Any suggestions, feedback, comments, criticisms are most welcome. Please email me at kamaraju at gmail dot com. I am planning to improve upon this document. So if you have any question that you would like to see here or if there is a stale link hanging out or if the pictures/description are out of date or if you find any grammatical mistakes etc., please get in touch with me and I shall incorporate them ASAP.
If you managed to read this whole thing, please let me know what you think. Whether it is useful or not etc.,
Copyright © 2004-2016 Kamaraju Kusumanchi
Permission is granted to copy,
distribute and/or modify this
document under the
terms of the GNU
General
Public License, Version 2
or any later version published by
the Free
Software Foundation. It is distributed in the hope that it will be
useful, but
WITHOUT ANY WARRANTY.
Permission is granted to make and distribute verbatim copies of this document provided the copyright notice and this permission notice are preserved on all copies.
Permission is granted to copy and distribute modified versions of this document under the conditions for verbatim copying, provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one.
Permission is granted to copy and distribute translations of this document into another language, under the above conditions for modified versions, except that this permission notice may be included in translations approved by the Free Software Foundation instead of in the original English.