B.2.1. The Root Directory
A Debian system is organized along the Filesystem Hierarchy Standard (FHS). This standard defines the purpose of each directory. For instance, the top-level directories are described as follows:
/bin/
: basic programs;
/boot/
: Linux kernel and other files required for its early boot process;
/dev/
: device files;
/etc/
: configuration files;
/home/
: user's personal files;
/lib/
: basic libraries;
/media/*
: mount points for removable devices (CD-ROM, USB keys and so on);
/mnt/
: temporary mount point;
/opt/
: extra applications provided by third parties;
/root/
: administrator's (root's) personal files;
/run/
: volatile runtime data that does not persist across reboots;
/sbin/
: system programs;
/srv/
: data used by servers hosted on this system;
/tmp/
: temporary files; this directory is often emptied at boot;
/usr/
: applications; this directory is further subdivided into bin
, sbin
, lib
(according to the same logic as in the root directory). Furthermore, /usr/share/
contains architecture-independent data. /usr/local/
is meant to be used by the administrator for installing applications manually without overwriting files handled by the packaging system (dpkg
).
/var/
: variable data handled by daemons. This includes log files, queues, spools, caches and so on.
Note that many modern distributions, Debian included, are shipping /bin
, /sbin
and /lib
as symlinks to the corresponding directories below /usr
so that all programs and libraries are available in a single tree. It makes it easier to protect the integrity of the system files, and to share those system files among multiple containers, etc.
B.2.2. The User's Home Directory
The contents of a user's home directory is not standardized, but there are still a few noteworthy conventions. One is that a user's home directory is often referred to by a tilde (“~”). That is useful to know because command interpreters automatically replace a tilde with the correct directory (usually /home/user/
).
Traditionally, application configuration files are often stored directly under the user's home directory, but their names usually start with a dot (for instance, the mutt
email client stores its configuration in ~/.muttrc
). Note that filenames that start with a dot are hidden by default; and ls
only lists them when the -a
option is used, and graphical file managers need to be told to display hidden files.
Some programs also use multiple configuration files organized in one directory (for instance, ~/.ssh/
). Some applications also use their directory to store a cache of downloaded data. This means that those directories can end up using a lot of disk space.
These configuration files stored directly in a user's home directory, often collectively referred to as dotfiles, have long proliferated to the point that these directories can be quite cluttered with them. Fortunately, an effort led collectively under the FreeDesktop.org umbrella has resulted in the “XDG Base Directory Specification”, a convention that aims at cleaning up these files and directories. This specification states that configuration files should be stored under ~/.config/
, cache files under ~/.cache/
, and application data files under ~/.local/
(or subdirectories thereof). This convention has been gaining traction, and many applications (especially graphical ones) are following it.
Graphical desktops usually display the contents of the ~/Desktop/
directory (or whatever the appropriate translation is for systems not configured in English) on the desktop (i.e. what is visible on screen once all applications are closed or iconized).
Finally, the email system sometimes stores incoming emails into a ~/Mail/
directory.