bash-hackers-wiki/docs/dict/hardlink.md

51 lines
1.3 KiB
Markdown
Raw Normal View History

2023-07-05 11:06:16 +02:00
# Hardlink
Also the article for:
- filename
A hardlink associates a *filename* with a [file](../dict/file.md). That
2023-07-05 11:06:16 +02:00
name is an entry in a directory listing. Of course a file can have more
hardlinks to it (usually the number of hardlinks to a file is limited),
but all hardlinks to a file must reside on the same
`filesystem` as the file itself!
2023-07-05 11:06:16 +02:00
What you usually call a file is just a name for that file, and thus, a
hardlink.
The difference between a [symbolic link](../dict/symlink.md) and a hard
2023-07-05 11:06:16 +02:00
link is that there is no easy way to differentiate between a \'real\'
file and a hard link, let's take a look at the example:
2023-07-05 11:06:16 +02:00
\* create an empty file
$ touch a
\* create a hard link \'b\' and sym link \'c\' to empty file
$ ln a b
$ ln -s a c
2024-03-30 20:09:26 +01:00
as you can see file(1) can't differentiate between a real file \'a\'
2023-07-05 11:06:16 +02:00
and a hard link \'b\', but it can tell \'c\' is a sym link
$ file *
a: empty
b: empty
c: symbolic link to `a'
`ls -i` prints out the inode numbers of files, if two files have the
same inode number AND are on the same file system it means they are
**hardlinked**.
$ ls -i *
5262 a 5262 b 5263 c
2024-03-30 20:09:26 +01:00
hard links don't consume additional space on the filesystem, the space
2023-07-05 11:06:16 +02:00
is freed when the last hard link pointing to it is deleted.
## See also
- [file](../dict/file.md)
- [symlink](../dict/symlink.md)