Жесткая ссылка - Hard link - Wikipedia
Эта статья возможно содержит оригинальные исследования.Октябрь 2010 г.) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
В вычисление, а жесткая ссылка это запись в каталоге который связывает имя с файл на файловая система. Все на основе каталога файловые системы должны иметь по крайней мере одну жесткую ссылку, дающую исходное имя для каждого файла. Период, термин "жесткая ссылка”Обычно используется только в файловых системах, которые позволяют использовать более одной жесткой ссылки для одного и того же файла.
Создание дополнительной жесткой ссылки приводит к тому, что одному файлу присваивается несколько имен (например, разные имена в разных каталогах), все из которых независимо подключаются к одним и тем же данным на диске, ни одно из которых не зависит от других.[1] Это вызывает эффект псевдонима: например если файл открывается по одному из своих имен и в его содержимое вносятся изменения, то эти изменения также будут видны, когда файл открывается с другим именем. Напротив, мягкая ссылка или же «Ярлык» в файл не является прямой ссылкой на сами данные, а представляет собой короткий файл, содержащий текст имя файла, или расположение, которое дает прямой доступ к еще одному имени файла в некотором каталоге. Имя, содержащееся в или упоминаемое в мягкая ссылка может быть жесткой ссылкой или другой мягкой ссылкой. Это также создает алиасинг, но по-другому.
Каждый каталог сам по себе является файлом, особенным только потому, что он содержит список имен файлов, поддерживаемый файловая система.Поскольку каталоги сами по себе являются файлами, возможны множественные жесткие ссылки на каталоги, которые могут создать круговую структуру каталогов, а не структуру ветвления, такую как дерево. По этой причине создание жестких ссылок на каталоги иногда запрещено.
Множественные жесткие ссылки, то есть несколько записей каталога к одному и тому же файлу, поддерживаются POSIX -соответствует и частично соответствует POSIX операционные системы, Такие как Linux, Android, macOS, а также Windows NT4[2] и позже Windows NT операционные системы.
Поддержка также зависит от типа используемой файловой системы. Например, NTFS файловая система поддерживает несколько жестких ссылок, а ТОЛСТЫЙ и ReFS не.
использование
На POSIX -соответствующие и частично POSIX-совместимые операционные системы, такие как все Unix-подобный системы, дополнительные жесткие ссылки на существующие файлы создаются с помощью связь()
системный вызов, или пер и связь утилиты командной строки. В стат
Команда может показать, сколько жестких ссылок указывают на данный файл. Счетчик ссылок также включается в вывод ls -l
.
На Майкрософт Виндоус, Только NTFS реализует жесткие ссылки.[3] Он поддерживается начиная с Windows NT 3.1, хотя только с Windows 2000 есть CreateHardLink ()
Функция API для создания жестких ссылок путем присвоения нового имени записи записи главной таблицы файлов (аналогично inodes ). Обычный Удалить файл()
можно использовать для их удаления. Чтобы создать жесткую ссылку, можно использовать mklink /ЧАС
командовать Windows NT 6.0 и более поздние системы (такие как Виндоус виста ), а в более ранних системах (Windows XP, Windows Server 2003) с использованием fsutil.exe создать жесткую ссылку
.[4] Начиная с Windows Vista, жесткие ссылки используются Windows Component Store (WinSxS ) для отслеживания различных версий DLL хранится на жестком диске. Unix-подобное программное обеспечение для эмуляции или совместимости, работающее в Windows, например Cygwin и Подсистема для UNIX-приложений, разрешить использование интерфейсов POSIX под Windows.
Процесс разъединение отделяет имя от данные на объем без разрушения связанных данных. Данные по-прежнему доступны, если существует хотя бы одна ссылка, указывающая на них. Когда последняя ссылка удаляется, пространство считается свободным.[5]
Процесс называется восстановление позволяет воссоздавать ссылки на данные, которые больше не связаны с именем. Однако этот процесс доступен не во всех системах и часто ненадежен. Когда файл удаляется, он добавляется на карту свободного пространства для повторного использования. Если часть удаленного файлового пространства занята новыми данными, восстановление будет неудачным, потому что некоторые или все предыдущие данные будут перезаписанный, и может привести к перекрестным ссылкам с новыми данными и повреждение файловой системы. Кроме того, удалены файлы на твердотельные накопители могут быть в любой момент стерты запоминающим устройством для использования в качестве свободного места.
Счетчик ссылок
Наиболее файловые системы которые поддерживают жесткие ссылки, используют подсчет ссылок. An целое число значение сохраняется с каждым физическим данные раздел. Это целое число представляет общее количество жестких ссылок, которые были созданы для указания на данные. Когда создается новая ссылка, это значение увеличивается на единицу. При удалении ссылки значение уменьшается на единицу. Если счетчик ссылок становится равным нулю, операционная система обычно автоматически освобождает пространство данных файла, если ни один процесс не открыл файл для доступа, но она может решить не делать это немедленно, либо для повышения производительности, либо для включения восстановить команда.
Поддержание этого значения гарантирует отсутствие болтающихся жестких ссылок, указывающих в никуда (что может и происходит с символическими ссылками), и этот файл файловой системы и связанный с ним индекс будет сохраняться до тех пор, пока на него указывает одна жесткая ссылка (ссылка на каталог) или пока какой-либо процесс сохраняет связанный файл открытым, снимая бремя этого учета с программиста или пользователя. Это простой метод для файловой системы, позволяющий отслеживать использование данной области хранения, поскольку нулевые значения указывают на свободное пространство, а ненулевые значения указывают на используемое пространство.
На POSIX -совместимые операционные системы, такие как многие Unix -variants счетчик ссылок для файла или каталога возвращается stat () или системные вызовы fstat () в st_nlink
поле struct stat
.
Пример
На рисунке справа две жесткие ссылки с именами «LINK A.TXT» и «LINK B.TXT» указывают на одни и те же физические данные.
Если файл «LINK A.TXT» открыт в редакторе, изменен и сохранен, то эти изменения будут видны, если файл «LINK B.TXT» затем будет открыт для просмотра, поскольку оба имени файла указывают на одни и те же данные («открыт ", потому что на POSIX системы, связанные дескриптор файла остается в силе после открытия, даже если исходный файл перемещен). То же самое верно, если файл был открыт как «LINK B.TXT» - или любое другое имя, связанное с данными.
Однако некоторые редакторы нарушают концепцию жестких ссылок, например emacs. При открытии файла «LINK B.TXT» для редактирования, emacs сначала переименовывает «LINK B.TXT» в «LINK B.TXT ~», загружает «LINK B.TXT ~» в редактор и сохраняет измененное содержимое в вновь созданный "LINK B.TXT". При таком подходе две жесткие ссылки теперь «LINK A.TXT» и «LINK B.TXT ~» (файл резервной копии); «LINK B.TXT» теперь будет иметь только одну ссылку и больше не будет использовать те же данные, что и «LINK A.TXT». (Это поведение можно изменить с помощью переменной emacs резервное копирование путем копирования
.)
Может быть создано любое количество жестких ссылок на физические данные. Чтобы получить доступ к данным, пользователю нужно только указать имя любой существующей ссылки; операционная система определит местонахождение фактических данных.
Если одна из ссылок удалена с POSIX функция отмены связи (например, с UNIX rm
command), то данные будут доступны по любой другой оставшейся ссылке. Если все ссылки удалены и ни один процесс не открыл файл, то пространство, занятое данными, освобождается, что позволяет повторно использовать их в будущем. Эта семантика позволяет удалять открытые файлы, не влияя на процесс, который их использует. Этот метод обычно используется для того, чтобы временные файлы удаляются автоматически при завершении программы, в том числе в случае аварийного завершения.
Ограничения жестких ссылок
Для предотвращения циклов в файловой системе и сохранения интерпретации ..
(родительский каталог), многие современные операционные системы не допускают жестких ссылок на каталоги. Система UNIX V позволил им, но только суперпользователь имел разрешение делать такие ссылки.[6] Mac OS X v10.5 (Leopard) и более новые используют жесткие ссылки на каталоги для Машина времени только механизм резервного копирования.[7] Символические ссылки и Точки соединения NTFS вместо этого обычно используются для этой цели.
Жесткие ссылки могут быть созданы для файлов только на одном томе. Если требуется ссылка на файл на другом томе, ее можно создать с помощью символическая ссылка.
Максимальное количество жестких ссылок на один файл ограничено размером счетчика ссылок. В Unix-подобных системах счетчик обычно имеет размер машинного слова (32- или 64-разрядный: 4 294 967 295 или 18 446 744 073 709 551 615 ссылок, соответственно), хотя в некоторых файловых системах количество жестких ссылок более строго ограничено их форматом на диске. По состоянию на Linux 3.11, ext4 Файловая система ограничивает количество жестких ссылок в файле до 65 000.[8] Windows с NTFS файловая система имеет ограничение в 1024 жестких ссылки на файл.[9]
Жесткие ссылки были раскритикованы Нилом Брауном как «требующий особого обслуживания дизайн». Еженедельные новости Linux, поскольку они усложняют разработку программ, которые обрабатывают деревья каталогов, включая архиваторы и инструменты использования диска, такие как ду, который должен позаботиться о дедупликации файлов, которые связаны несколько раз в иерархия. Браун также обращает внимание на то, что План 9 от Bell Labs, предполагаемый преемник Unix, не включает концепцию жесткой ссылки.[10]
Смотрите также
- Жирная ссылка
- Символическая ссылка или же мягкая ссылка, который, в отличие от жесткой ссылки, предоставляет только текст «фактического» имени файла, а не сами данные файла.
- Символьная ссылка NTFS - реализация NTFS.
- Точка соединения NTFS - аналогично символической ссылке на каталог NTFS, но не то же самое.
- псевдоним (Mac OS) - метод связывания файлов, представленный в классическая Mac OS Система 7, и все еще доступно в macOS, что в некотором роде похоже на символическую ссылку. Обратите внимание, что настоящие символические ссылки также доступны в macOS.
- тень (OS / 2) - реализация OS / 2
- ln (Unix) - The
пер
команда, которая используется для создания новых ссылок в Unix-подобных системах. - освобождается - The
освобождается
команда освобождает дисковое пространство, заменяя дублирующиеся хранилища данных автоматически созданными жесткими ссылками
Примечания
- ^ Питчер, Лью. «Вопросы и ответы: разница между жесткими и мягкими ссылками».
- ^ "Расширение оболочки ссылки".
- ^ "Как работают жесткие ссылки".
- ^ «Жесткие ссылки NTFS, соединения каталогов и ярлыки Windows». flexhex.com.
- ^ «AllDup - программа для поиска дубликатов файлов (бесплатное ПО)».
- ^ Бах, Морис Дж. (1986). Дизайн операционной системы UNIX. Прентис Холл. стр.128.
- ^ Понд, Джеймс (31 августа 2013 г.). «Как машина времени творит чудеса». Хранилище событий файловой системы, жесткие ссылки. Получено 19 мая, 2019.
- ^ "Дерево исходных текстов ядра Linux, fs / ext4 / ext4.h, строка 229".
- ^ «MSDN - функция CreateHardLink». Получено 14 января 2016.
- ^ Нил Браун (23 ноября 2010 г.). "Призраки прошлого Unix, часть 4: Проекты, требующие особого обслуживания". Еженедельные новости Linux. Получено 20 апреля 2014.