KEMBAR78
File System in Unix | PDF | Computer File | File System
0% found this document useful (0 votes)
57 views31 pages

File System in Unix

Uploaded by

Rishabh Chandila
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
57 views31 pages

File System in Unix

Uploaded by

Rishabh Chandila
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 31

File System

Dr. Sarvesh Tanwar


File System
• Unix file system is a logical method of organizing and storing large
amounts of information in a way that makes it easy to manage. A file
is a smallest unit in which the information is stored. Unix file system
has several important features. All data in Unix is organized into files.
All files are organized into directories. These directories are organized
into a tree-like structure called the file system.
Example
Directories or Files and their description –
• / : The slash / character alone denotes the root of the file system tree.
• /bin : Stands for “binaries” and contains certain fundamental utilities, such as ls or cp,
which are generally needed by all users.
• /boot : Contains all the files that are required for successful booting process.
• /dev : Stands for “devices”. Contains file representations of peripheral devices and
pseudo-devices.
• /etc : Contains system-wide configuration files and system databases. Originally also
contained “dangerous maintenance utilities” such as init, but these have typically
been moved to /sbin or elsewhere.
• /home : Contains the home directories for the users.
• /lib : Contains system libraries, and some critical files such as kernel modules or
device drivers.
• /media : Default mount point for removable devices, such as USB sticks, media
players, etc.

• /mnt : Stands for “mount”. Contains filesystem mount points. These are used, for
example, if the system uses multiple hard disks or hard disk partitions. It is also
often used for remote (network) filesystems, CD-ROM/DVD drives, and so on.

• /proc : procfs virtual filesystem showing information about processes as files.

• /root : The home directory for the superuser “root” – that is, the system
administrator. This account’s home directory is usually on the initial filesystem, and
hence not in /home (which may be a mount point for another filesystem) in case
specific maintenance needs to be performed, during which other filesystems are
not available. Such a case could occur, for example, if a hard disk drive suffers
physical failures and cannot be properly mounted.
Mounting
• Mounting makes file systems, files, directories, devices and special
files available for use and available to the user.
• Its counterpart umount instructs the operating system that the file
system should be disassociated from its mount point, making it no
longer accessible and may be removed from the computer.
• /tmp : A place for temporary files. Many systems clear this directory
upon startup; it might have tmpfs mounted atop it, in which case its
contents do not survive a reboot, or it might be explicitly cleared by a
startup script at boot time.
• /sbin: Contains binary (executable) files, usually for system
administration. For example, fdisk and ifconfig utilities
• /kernel : Contains kernel files
• /usr : Originally the directory holding user home directories, its use has changed.
It now holds executables, libraries, and shared resources that are not system
critical, like the X Window System, KDE, Perl, etc. However, on some Unix
systems, some user accounts may still have a home directory that is a direct
subdirectory of /usr, such as the default as in Minix. (on modern systems, these
user accounts are often related to server or system use, and not directly used by
a person).

• /usr/bin : This directory stores all binary programs distributed with the operating
system not residing in /bin, /sbin or (rarely) /etc.

• /usr/include : Stores the development headers used throughout the system.


Header files are mostly used by the #include directive in C/C++ programming
language.
• /usr/lib : Stores the required libraries and data files for programs
stored within /usr or elsewhere.
• /var : A short for “variable.” A place for files that may change often –
especially in size, for example e-mail sent to users on the system, or
process-ID lock files.
• /var/log : Contains system log files.
• /var/mail : The place where all the incoming mails are stored. Users
(other than root) can access their own mail only. Often, this directory
is a symbolic link to /var/spool/mail.
• /var/spool : Spool directory. Contains print jobs, mail spools and
other queued tasks.
• /var/tmp : A place for temporary files which should be preserved
between system reboots.
Types of Unix File System
Unix supports four types of files
• Ordinary files: These are usually text files. Programs written in
specific programming languages may have specific extension. For
instance, programs written in ‘C’ have a ‘.c’ extension. These are
usually the files users create most often using an editor.
• Directories: Subdirectories are treated as files by Unix
• Binary files: These are executables
• Special Files: Special files provide input/output capability for Unix
environment
Ordinary files
• An ordinary file is a file on the system that contains data, text, or
program instructions.
• Used to store your information, such as some text you have written or
an image you have drawn. This is the type of file that you usually work
with.
• Always located within/under a directory file.
• Do not contain other files.
• In long-format output of ls -l, this type of file is specified by the “-”
symbol.
Directories
Directories – Directories store both special and ordinary files. For users familiar with Windows or Mac OS,
UNIX directories are equivalent to folders. A directory file contains an entry for every file and subdirectory that
it houses. If you have 10 files in a directory, there will be 10 entries in the directory. Each entry has two
components.
(1) The Filename
(2) A unique identification number for the file or directory (called the inode number)

• Branching points in the hierarchical tree.


• Used to organize groups of files.
• May contain ordinary files, special files or other directories.
• Never contain “real” information which you would work with (such as text). Basically, just used for
organizing files.
• All files are descendants of the root directory, ( named / ) located at the top of the tree.
• In long-format output of ls –l , this type of file is specified by the “d” symbol.
Special Files
• Special Files – Used to represent a real physical device such as a printer,
tape drive or terminal, used for Input/Output (I/O) operations.
• Device or special files are used for device Input/Output(I/O) on UNIX
and Linux systems. They appear in a file system just like an ordinary file
or a directory.

On UNIX systems there are two flavors of special files for each device,
• character special files and
• block special files :
• When a character special file is used for device Input/Output(I/O),
data is transferred one character at a time. This type of access is
called raw device access.
• When a block special file is used for device Input/Output(I/O), data is
transferred in large fixed-size blocks. This type of access is called
block device access.
Pipes
• Pipes – UNIX allows you to link commands together using a pipe.
The pipe acts a temporary file which only exists to hold data from
one command until it is read by another.
• A Unix pipe provides a one-way flow of data. The output or result of
the first command sequence is used as the input to the second
command sequence.
• To make a pipe, put a vertical bar (|) on the command line between
two commands. For example: who | wc -l
• In long-format output of ls –l , named pipes are marked by the “p”
symbol.
File Attributes
File attributes

• file name: the name associated with the file (recall, this can be any type of file)
• modification date: the date the file was last modified, i.e. a "time-stamp". If
the file has not been modified within the last year (or six months for Linux),
the year of last modification is displayed.
• size: the size of the file in bytes (i.e. characters).2
• group: associated group for the file
• owner: the owner of the file
• number of links: the number of other links associated with this file
• permission modes: the permissions assigned to the file for the owner, the
group and all others.
Modifying File Permissions
inode
• An Inode number is a uniquely existing number for all the files in
Linux and all Unix type systems.
• When a file is created on a system, a file name and Inode number is
assigned to it.
• Generally, to access a file, a user uses the file name but internally file
name is first mapped with respective Inode number stored in a table.
• In Unix based operating system each file is indexed by an Inode. Inode
are special disk blocks they are created when the file system is
created. The number of Inode limits the total number of
files/directories that can be stored in the file system.

• Inode number is also known as index number. An inode is a unique


number assigned to files and directories while it is created. The inode
number will be unique to entire filesystem.
Example
• When a file is created inside a directory then the file-name and Inode
number are assigned to file. These two entries are associated with
every file in a directory. The user might think that the directory
contains the complete file and all the extra information related to it
but this might not be the case always. So we see that a directory
associates a file name with its Inode number.
• When a user tries to access the file or any information related to the
file then he/she uses the file name to do so but internally the file-
name is first mapped with its Inode number stored in a table. Then
through that Inode number the corresponding Inode is accessed.
There is a table (Inode table) where this mapping of Inode numbers
with the respective Inodes is provided.

23
When are Inodes created?
• As we all now know that Inode is a data structure that contains
information of a file. Since data structures occupy storage then an
obvious question arises about when the Inodes are created in a
system? Well, space for Inodes is allocated when the operating
system or a new file system is installed and when it does its initial
structuring. So this way we can see that in a file system, maximum
number of Inodes and hence maximum number of files are set.
inode
• An inode is a data structure in UNIX operating systems that contains
important information pertaining to files within a file system. When a
file system is created in UNIX, a set amount of inodes is created, as
well. Usually, about 1 percent of the total file system disk space is
allocated to the inode table.
• The inode table contains a listing of all inode numbers for the
respective file system. When users search for or access a file, the
UNIX system searches through the inode table for the correct inode
number. When the inode number is found, the command in question
can access the inode and make the appropriate changes if applicable.
Example
• Take, for example, editing a file with vi. When you type vi <filename>,
the inode number is found in the inode table, allowing you to open
the inode. Some attributes are changed during the edit session of vi,
and when you have finished and typed :wq, the inode is closed and
released. This way, if two users were to try to edit the same file, the
inode would already have been assigned to another user ID (UID) in
the edit session, and the second editor would have to wait for the
inode to be released.
The following information is stored in inode:
• File type: regular file, directory, pipe etc.
• Permissions to that file: read, write, execute
• Link count: The number of hard link relative to an inode
• User ID: owner of file
• Group ID: group owner
• Size of file: or major/minor number in case of some special files
• Time stamp: access time, modification time and (inode) change time
• Attributes: immutable' for example
• Access control list: permissions for special users/groups
• Link to location of file
• Other metadata about the file
Inode Contents
• An Inode is a data structure containing metadata about the files.
• Following contents are stored in the Inode from a file:
• User ID of file
• Group ID of file
• Device ID
• File size
• Date of creation
• Permission
• Owner of the file
• File protection flag
• Link counter to determine number of hard links
ls -id new1 [To check inode contents]
Inode Table

• The Inode table contains all the Inodes and is created when file
system is created. The df -i command can be used to check how many
inodes are free and left unused in the filesystem.
• df -i
Inode Number
• Each Inode has a unique number and Inode number can be seen with
the help of ls -li command.
• Ls –li disk1
https://linoxide.com/linux-command/linux-inode/#:~:text=For%20example%2C%20the%20inode
%20contains,decided%20at%20filesystem%20creation%20time.

You might also like