Iâ€™ve already written about conceptual information regarding file system, especially data structure and related terms that help you become a successful system administrator. However I do get few emails asking about /opt directory or /usr or /lost+found directories and their purpose on the system.
Exploring Linux File System Hierarchy
A typical Linux system has the following directories:
=> / : This is the root directory.
=> /bin : This directory contains executable programs which are needed in single user mode and to bring the system up or repair it.
=> /boot : Contains static files for the boot loader. This directory only holds the files which are needed during the boot process.
=> /dev : Special or device files, which refer to physical devices such as hard disk, keyboard, monitor, mouse and modem etc
=> /etc : Contains configuration files which are local to the machine. Some larger software packages, like Apache, can have their own subdirectories below /etc i.e. /etc/httpd. Some important subdirectories in /etc:
- /etc/skel : When a new user account is created, files from this directory are usually copied into the userâ€™s home directory.
- /etc/X11 : Configuration files for the X11 window system .
- /etc/sysconfig : Important configuration file used by SysV script stored in /etc/init.d and /etc.rcX directories
- /etc/cron.* : cron daemon configuration files which is used to execute scheduled commands
=> /home : Your sweet home to store data and other files. However in large installation yhe structure of /home directory depends on local administration decisions.
=> /lib : This directory should hold those shared libraries that are necessary to boot the system and to run the commands in the root filesystem.
=> /lib64 : 64 bit shared libraries that are necessary to boot the system and to run the commands in the root filesystem.
=> /mnt : This directory contains mount points for temporarily mounted filesystems
=> /opt : This directory should contain add-on packages such as install download firefox or static files
=> /proc : This is a mount point for the proc filesystem, which provides information about running processes and the kernel.
=> /root : This directory is usually the home directory for the root user.
=> /sbin : Like /bin, this directory holds commands needed to boot the system, but which are usually not executed by normal users, root / admin user specific commands goes here.
=> /tmp : This directory contains temporary files which may be deleted with no notice, such as by a regular job or at system boot up.
=> /usr : This directory is usually mounted from a separate partition. It should hold only sharable, read-only data, so that it can be mounted by various machines run ning Linux (useful for diskless client or multiuser Linux network such as university network). Programs, libraries, documentation etc. for all user-related programs.
=> /var : This directory contains files which may change in size, such as spool and log files.
=> /lost+found : Every partition has a lost+found in its upper directory. Files that were saved during failures are here, for e.g ext2/ext3 fsck recovery.
How do I get information about each and every directory from command prompt?
Above list just summaries important directories, you can get list by entering the following command to display description of the file system hierarchy (works under all other UNIX like oses such as HP-UX ):
$ man hier
List contents of directories in a tree-like format
ls command is basic tool for exploring file system. You can use tree command for a recursive directory listing. It produces a depth indented listing of files.
|-- DIR_COLORS |-- DIR_COLORS.xterm |-- Muttrc |-- Muttrc.local |-- NetworkManager |-- X11 | |-- Xmodmap | |-- Xresources | |-- applnk | |-- fs | | `-- config ..... ....... ..
find is another useful command to search for files in a directory hierarchy.
- Understanding UNIX / Linux File System
- Understanding UNIX / Linux filesystem directories
- Understanding the Linux file system directories / hierarchy
- Understanding UNIX / Linux filesystem Superblock
- Understanding filesystem Inodes
- What is a hard and symbolic (soft) link in Linux or Unix?
- Why isn't it possible to create hard links across file system boundaries?
- Surviving a Linux Filesystem Failures
- Linux / UNIX Delete or Remove Files With Inode Number
🐧 Get the latest tutorials on Linux, Open Source & DevOps via:
|Category||List of Unix and Linux commands|
|Firewall||Alpine Awall • CentOS 8 • OpenSUSE • RHEL 8 • Ubuntu 16.04 • Ubuntu 18.04 • Ubuntu 20.04|
|Network Utilities||dig • host • ip • nmap|
|OpenVPN||CentOS 7 • CentOS 8 • Debian 10 • Debian 8/9 • Ubuntu 18.04 • Ubuntu 20.04|
|Package Manager||apk • apt|
|Processes Management||bg • chroot • cron • disown • fg • jobs • killall • kill • pidof • pstree • pwdx • time|
|Searching||grep • whereis • which|
|User Information||groups • id • lastcomm • last • lid/libuser-lid • logname • members • users • whoami • who • w|
|WireGuard VPN||Alpine • CentOS 8 • Debian 10 • Firewall • Ubuntu 20.04|