


Reason: Introducing a hard connection to the directory may introduce a loop in the directory. When the directory is traversed, the system will fall into an infinite loop, which will result in the inability to locate the access directory. The directory structure of Linux is a tree with "/directory" as the root node. If custom hard links are allowed, it is likely to destroy this structure and even form a loop; and once a loop is formed, for commands that need to traverse the directory tree , is fatal. Therefore, in order to avoid damaging the directory tree structure, Linux does not allow users to customize hard links on the directory.
#The operating environment of this tutorial: linux7.3 system, Dell G3 computer.
LINUX hard links cannot be linked to the directory because the introduction of a hard link to the directory may introduce a loop in the directory. When the directory is traversed, the system will fall into an infinite loop, which will result in the inability to locate the directory. Visit catalog.
In the Linux system, each file (directory is also a file) corresponds to an inode structure. The inode data structure contains information about the file type (directory, ordinary file, symbolic link file, etc.), and That is to say, the operating system can determine the symbolic link when traversing the directory. Since it can determine the symbolic link, of course it can take some measures to prevent entering an excessive loop. The system stops traversing after encountering 8 symbolic links in a row. This This is why directory symbolic connections do not enter an infinite loop. However, for hard connections, due to the limitations of the data structure and algorithm used in the operating system, it is currently impossible to prevent such an infinite loop.
The essence of hard connection in linux
Before discussing the problem, let’s talk about the essence of hard connection.
The hard link is actually the content of the block pointed to by the inode of the directory. Each record in the directory block is a hard link. The directory itself is a type of file in Linux (directory file, symbol d), and the file content of the "directory file" is a hard link.
For example (note the change in the number of directory connections in the picture):
The diagram before and after the change in the number of tmp directory connections is as follows (the red line indicates the source of the connection number) ):
Through the above example, we can find that the number of hard links when a directory is just created is 2, one of which comes from the parent directory and the other from itself. of".". If you create a subdirectory for the directory, the number of hard connections will change from 1 to 3. This is because there is an additional ".." connection from the subdirectory.
Some people may ask here, doesn’t it mean that hard links cannot be used for directories? What's going on with the demo above?
A concept needs to be clarified here, "hard links cannot be used for directories", which means that hard links to directories cannot be customized by users, but can only be maintained by the operating system. In fact, directories and hard links are inseparable and integrated with each other. The "hard link" itself is actually the way a directory maintains its sub-file names & sub-directory names.
The nightmare of custom hard connections: loops
After talking about the nature of hard connections, we can return to today’s topic: why not Allow user-defined hard links to directories?
We know that the directory structure of Linux is a tree with "/directory" as the root node. If custom hard links are allowed, it is likely to destroy this structure or even form a loop. For example, the following command If it can be executed successfully:
Once a loop is formed, it is fatal for commands that need to traverse the directory tree (for example, from top to bottom The du command that traverses from bottom to top, and the pwd command that traverses from bottom to top). Therefore, in order to avoid damaging the directory tree structure, Linux does not allow users to customize hard links on the directory. The reason why soft links do not have this restriction is that soft link files have a special file type that can be recognized by the system, while "hard link files" are no different from normal files of the system and cannot be judged.
Related recommendations: "Linux Video Tutorial"
The above is the detailed content of Why can't Linux hard links link directories?. For more information, please follow other related articles on the PHP Chinese website!

Maintenance mode is used for system maintenance and repair, allowing administrators to work in a simplified environment. 1. System Repair: Repair corrupt file system and boot loader. 2. Password reset: reset the root user password. 3. Package management: Install, update or delete software packages. By modifying the GRUB configuration or entering maintenance mode with specific keys, you can safely exit after performing maintenance tasks.

Linux network configuration can be completed through the following steps: 1. Configure the network interface, use the ip command to temporarily set or edit the configuration file persistence settings. 2. Set up a static IP, suitable for devices that require a fixed IP. 3. Manage the firewall and use the iptables or firewalld tools to control network traffic.

Maintenance mode plays a key role in Linux system management, helping to repair, upgrade and configuration changes. 1. Enter maintenance mode. You can select it through the GRUB menu or use the command "sudosystemctlisolaterscue.target". 2. In maintenance mode, you can perform file system repair and system update operations. 3. Advanced usage includes tasks such as resetting the root password. 4. Common errors such as not being able to enter maintenance mode or mount the file system, can be fixed by checking the GRUB configuration and using the fsck command.

The timing and reasons for using Linux maintenance mode: 1) When the system starts up, 2) When performing major system updates or upgrades, 3) When performing file system maintenance. Maintenance mode provides a safe and controlled environment, ensuring operational safety and efficiency, reducing impact on users, and enhancing system security.

Indispensable commands in Linux include: 1.ls: list directory contents; 2.cd: change working directory; 3.mkdir: create a new directory; 4.rm: delete file or directory; 5.cp: copy file or directory; 6.mv: move or rename file or directory. These commands help users manage files and systems efficiently by interacting with the kernel.

In Linux, file and directory management uses ls, cd, mkdir, rm, cp, mv commands, and permission management uses chmod, chown, and chgrp commands. 1. File and directory management commands such as ls-l list detailed information, mkdir-p recursively create directories. 2. Permission management commands such as chmod755file set file permissions, chownuserfile changes file owner, and chgrpgroupfile changes file group. These commands are based on file system structure and user and group systems, and operate and control through system calls and metadata.

MaintenanceModeinLinuxisaspecialbootenvironmentforcriticalsystemmaintenancetasks.Itallowsadministratorstoperformtaskslikeresettingpasswords,repairingfilesystems,andrecoveringfrombootfailuresinaminimalenvironment.ToenterMaintenanceMode,interrupttheboo

The core components of Linux include kernel, file system, shell, user and kernel space, device drivers, and performance optimization and best practices. 1) The kernel is the core of the system, managing hardware, memory and processes. 2) The file system organizes data and supports multiple types such as ext4, Btrfs and XFS. 3) Shell is the command center for users to interact with the system and supports scripting. 4) Separate user space from kernel space to ensure system stability. 5) The device driver connects the hardware to the operating system. 6) Performance optimization includes tuning system configuration and following best practices.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SublimeText3 Chinese version
Chinese version, very easy to use

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
