Сценарий - символическая ссылка NTFS или соединение?

Различия

┌───────────────┬──────────┬──────────┬──────┬───────────┬─────┐
│               │ Абсолютный │ Относительный │ Файл │ Каталог │ UNC │
├───────────────┼──────────┼──────────┼──────┼───────────┼─────┤
│ Символическая ссылка │ Да │ Да │ Да │ Да │ Да │
│ перекресток │ да │    -     │  -   │ да │  -  │
└───────────────┴──────────┴──────────┴──────┴───────────┴─────┘

сценарий

Давайте предположим, что мы создаем точку повторной обработки для создания перенаправления C:\SomeDir => D:\SomeDir

Поскольку для этого сценария требуются только локальные абсолютные пути, будет работать либо соединение, либо символическая ссылка. Есть ли в этой ситуации какое-либо преимущество от использования одного или другого?

Предположим Windows 7 для ОС, не учитывая обратную совместимость. (До Vista, символические ссылки изначально не поддерживаются, хотя существует сторонний драйвер, который обеспечивает поддержку символических ссылок в Windows XP.)

Обновить

Я нашел другое отличие.

  • Символическая ссылка - разрешения ссылки влияют только на операции удаления / переименования на самой ссылке, доступ на чтение / запись (к цели) регулируется разрешениями цели
  • Junction - разрешения Junction влияют на перечисление, отзыв разрешений на соединении будет запрещать перечисление файлов через этот переход, даже если целевая папка имеет более разрешающие списки ACL.

Разрешения делают его интересным, так как символические ссылки могут позволить устаревшим приложениям получать доступ к файлам конфигурации в областях с ограниченным доступом UAC (таких как %ProgramFiles%) без изменения существующих прав доступа, сохраняя файлы в неограниченном месте и создавая символические ссылки в ограниченном каталоге.

Обновление 2

Windows 8.1 будет разрешать символические ссылки на каталоги при переходе по ним через текстовое поле в Save As... диалоговое окно. Соединения не расширены.

5 ответов

Я понимаю, что символические ссылки NTFS являются заменой для переходов в более новых ОС Windows (Vista/7/8), поскольку они функционируют аналогичным образом, но также предоставляют дополнительную функциональность (удаленные точки). Поэтому, если вы работаете только с более новыми операционными системами, нет никаких причин не использовать опцию символической ссылки.

Я думаю, что точки соединения имеют более широкую поддержку в программном обеспечении резервного копирования, чем символические ссылки. Вы должны проверить, с какой программой резервного копирования вы используете, какая функция поддерживается.

Если не поддерживается, точка символической ссылки / соединения будет либо сохранена в виде отдельного каталога (и восстановлена ​​как таковая), либо не будет сохранена вообще.

Кроме проблемы с резервным копированием, я не вижу причин, чтобы отдавать предпочтение одному над другим, в вашем конкретном случае (локальный каталог).

Соединения NTFS могут указывать только на каталоги, в то время как символические ссылки также работают с файлами.

Вот одно отличие, которое я заметил:

У меня есть каталог синхронизированных сценариев, переносимых приложений и т. Д. Я использую пакетный сценарий для создания соединения в каталоге меню "Пуск", которое указывает на каталог ярлыков для переносимых приложений.

Junction позволяет ярлыкам появляться в меню "Пуск". Когда я использую символическую ссылку, она не работает.

Может быть, я пропустил это где-то в комментариях, но одно очень важное различие между символическими ссылками и соединениями в Windows для меня - необходимые привилегии для создания обоих. While symlinks are by default only creatable using special permissions default users don't have, junctions can be created easily by all default users OOB and are therefore my preferred link type for dirs.

By default, members of the Administrators group have this right.

https://docs.microsoft.com/en-us/windows/device-security/security-policy-settings/create-symbolic-links

Другие вопросы по тегам