Linux/unix Inode

Source: Internet
Author: User
Tags disk usage

First, what is the inode?

To understand the inode, start with the file storage. The file is stored on the hard disk, and the minimum storage unit for the hard disk is called "Sector" (Sector). Each sector is stored 512 bytes (equivalent to 0.5KB).

When the operating system reads the hard disk, it does not read each sector, so the efficiency is too low, but the one-time continuous reading of multiple sectors, that is, one time to read a block. This "block", composed of multiple sectors, is the smallest unit of file access. "Block" size, the most common is 4KB, that is, eight consecutive sector to form a block.

File data is stored in "blocks", then obviously, we must also find a place to store the meta-information of the file, such as the creator of the file, the date the file was created, the size of the file, and so on. This area of stored file meta information is called Inode, and the Chinese name is "Index node".

The Inode content inode contains the meta-information of the file, specifically the following: * File bytes * File owner's user ID * file's group ID * file's read, write, execute permissions * file timestamp, a total of three: CTime refers to the inode last change  Time, mtime refers to the time the file content was last changed, atime refers to the time when the file was last opened. * Number of links, that is, how many file names point to this inode * file data block location

You can use the Stat command to view inode information for a file: Stat example.txt

In summary, all file information except the filename is present in the inode. As for why there is no file name, the following is explained in detail.

Third, the inode size of the inode will also consume hard disk space, so when the hard disk format, the operating system automatically divides the hard disk into two areas. One is the data area, the file data is stored, and the other is the Inode area (inode table), which holds the information contained in the Inode. The size of each inode node is typically 128 bytes or 256 bytes. The total number of inode nodes, given at the time of formatting, is usually set to one inode per 1KB or 2KB each. Assuming that the size of each inode node in a 1GB hard disk is 128 bytes, and one inode is set per 1KB, the Inode table will be about 128MB in size, accounting for 12.8% of the entire drive.

You can use the DF command to view the total number of inode per hard disk partition and the quantity that is already in use. Df-i view the size of each inode node, you can use the following command: sudo dumpe2fs-h/dev/hda | grep "Inode size" because each file must have an inode, it is possible that the inode has been exhausted, but the hard disk is not yet full. At this point, you cannot create a new file on your hard disk.

Iv. inode number Each inode has a number, and the operating system uses Inode numbers to identify different files.

It is worth repeating that the Unix/linux system does not use file names, and inode numbers are used to identify files. For the system, the file name is just an alias or nickname for the inode number to easily identify. On the surface, the user opens the file by file name. In fact, this process inside the system is divided into three steps: First, the system finds the inode number corresponding to the file name, and secondly, obtains the inode information through the inode number, and finally, according to the Inode information, finds the block of the file data and reads the data.

With the Ls-i command, you can see the inode number corresponding to the file name:

Ls-i Example.txt

V. Directory file Unix/linux system, directory is also a file. Opening the directory is essentially opening the directory file.

The structure of the catalog file is very simple, which is a list of a series of catalog items (dirent). Each directory entry consists of two parts: the file name of the included file, and the inode number that corresponds to the file name.

The LS command lists only all the file names in the directory file: The ls/etcls-i command lists the entire directory file, the file name and inode number: ls-i/etc If you want to view the details of a file, you must access the Inode node based on the inode number and read the information. The ls-l command lists the details of the file. Ls-l/etc

Six, hard links in general, the file name and inode number is the "one by one correspondence" relationship, each inode number corresponds to a file name. However, the Unix/linux system allows multiple filenames to point to the same inode number. This means that the same content can be accessed with different file names, and changes to the contents of the file affect all file names, but deleting a file name does not affect access to another file name. This is referred to as a "hard link".

The ln command can create a hard link:

ln source file target file after running this command, the source file is the same as the inode number of the destination file, pointing to the same inode. One of the inode information is called the "number of links," which records the total number of filenames pointing to the inode, which increases by 1. Conversely, deleting a file name causes the "number of links" in the Inode node to be reduced by 1. When this value is reduced to 0, indicating that no file name points to the Inode, the system reclaims the inode number and its corresponding block region.

Here, by the way, the "number of links" to the catalog file. When you create a catalog, two catalog entries are generated by default: "." and ".". The inode number of the former is the inode number of the current directory, which is equivalent to the "hard link" of the current directory, and the inode number is the inode number of the parent directory of the current directory, which is equivalent to the "hard link" of the parent directory. Therefore, the total number of "hard links" in any directory is always equal to 2 plus the total number of subdirectories (including hidden directories), where 2 is the "hard link" to the parent directory and the ". Hard link" in the current directory.

Seven, soft links in addition to hard links, there is a special case. The inode number for file A and file B is different, but the content of file A is the path to file B. When you read file A, the system automatically directs the visitor to file B. Therefore, regardless of which file you open, the final read is file B. At this point, file A is referred to as the "soft link" of File B (soft link) or "Symbolic link" (symbolic).

This means that file a depends on file B and if file B is deleted, opening file A will cause an error: "No such file or directory". This is the biggest difference between soft links and hard links: file a points to file B's file name, not file B's inode number, and file B's Inode "link count" does not change.

The ln-s command can create a soft link. Ln-s source file or directory destination file or directory

Viii. the special role of the inode due to the separation of inode numbers and filenames, this mechanism has led to some unix/linux system-specific phenomena. 1. Sometimes the file name contains special characters and cannot be deleted properly.  At this point, delete the Inode node directly, you can play the role of deleting files.  2. Move or rename the file, just change the file name without affecting the inode number. 3. After opening a file, the system will identify the file with the Inode number and no longer consider the filename.      Therefore, it is generally not possible for the system to know the file name from the inode number. The 3rd makes software updates simple and can be updated without shutting down the software, without requiring a restart. Because the system through the Inode number, identify the running files, not through the file name. Update, the new version of the file with the same file name, the generation of an inode, will not affect the running files. The next time you run this software, the file name will automatically point to the new version of the file, the old file's inode is recycled.

Nine Practical problems

In a low-profile Linux server (memory, hard disk relatively small) in the/data partition to create files, the system prompted insufficient disk space, with the df-h command to see the disk usage, found that the/data partition only used 66%, and 12G of the remaining space, it is said that this problem does not occur. later, using Df-i to view the index node (inode) of the/data partition, it was found to be full (iused=100%), which prevented the system from creating new directories and files.

Find Reason:

There are a very large number of small-byte cache files in the/data/cache directory, with no more blocks, but a lot of inode.

solution:
1, delete/data/ A portion of the file in the cache directory, releasing part of the inode for the/data partition.
2, connect the Newcache directory in the free partition/opt to/data/cache with a soft connection, and use the inode of the/OPT partition to alleviate the problem of insufficient/data partition inode:
ln-s/opt/newcache/data/cache

Linux/unix inode

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.