Вопрос или проблема
Работа с системами на базе Ubuntu.
Столкнувшись с замороженной файловой дескриптором при монтировании samba, советы в интернете предлагают добавить noserverino
в качестве опции для монтирования.
Читая документацию, в ней говорится:
Вы также можете использовать опцию монтирования “noserverino”, чтобы генерировать номера инодов меньше, чем 2 в степени 32 на клиенте. Но вы можете не правильно обнаруживать жесткие ссылки.
Это не особо много говорит для меня. Я не вижу, какие проблемы могут возникнуть из-за этого.
Какие негативные последствия могут быть от незнания того, что некоторые файлы являются одинаковыми жесткими ссылками, разве что у вас есть система, где вы вручную изменяете файлы множество раз?
Что касается части “генерации номеров инодов меньше, чем 2 в степени 32 на клиенте”… должен ли я предположить, что любые числа выше этого все равно будут генерироваться на сервере и корректно передаваться клиенту?
Учитывая, что это не дефолтная опция и её описание так мало, я немного беспокоюсь о неизвестных последствиях и/или поведении, если использовать её.
Может кто-то подробно объяснить это? Или дать какую-то уверенность в том, что это не сломается через год? Или с файловой системой с слишком большим количеством файлов?
Из чего-то подобного (где дается такой совет)
https://forums.unraid.net/topic/103945-psahow-to-proper-fix-for-smb-stale-file-handle/
похоже, что происходит смена управления инодами с серверной стороны на клиентскую.
Поскольку этому вопросу больше года, я предположу, что вы попробовали это, и все было в порядке!
.
Ответ или решение
Использование опции монтирования SMB "noserverino" на Ubuntu: Полные последствия
Работая с Ubuntu-системами, многие пользователи сталкиваются с проблемами при монтировании SMB, такими как "stale file handle". На данном этапе часто рекомендуют использовать параметр "noserverino". Давайте детально разберем, что это за опция и какие последствия она несет.
Что такое "noserverino"?
Опция "noserverino" в контексте монтирования SMB настраивает клиентскую машину использовать свои собственные номера inode, а не полагаться на серверные. В документации указано, что это позволяет генерировать номера inode, меньшие чем 2 в 32 степени.
Возможные последствия
-
Ошибка при обнаружении жестких ссылок: Когда используется "noserverino", клиент генерирует свои собственные номера inode. Это может привести к невозможности корректно отслеживать жесткие ссылки, поскольку они по своей природе зависят от номеров inode для идентификации идентичных файлов.
-
Совместимость с большим количеством файлов: Теоретически, номеров inode, генерируемых клиентом, достаточно для большинства файловых систем, однако могут возникнуть проблемы с масштабируемостью при работе с огромным количеством файлов.
-
Точность метаданных: Использование "noserverino" может повлиять на точность метаданных, связанных с файлами и каталогами, поскольку клиентская система не будет полностью синхронизирована с серверной в части номеров inode.
Советы и рекомендации
Если ваш текущий процесс работы не требует постоянной проверки и изменения файлов или создания множества жестких ссылок, использование опции "noserverino" может не вызвать значительных осложнений. Однако, если ваша работа предполагает интенсивное использование жестких ссылок или управления большими объемами метаданных, рекомендуется провести гораздо более детальное тестирование перед применением в производственных системах.
Также важно учитывать вероятность долгосрочных изменений в инфраструктуре — например, увеличение числа файлов — и потенциальное влияние этих изменений на использование "noserverino".
Заключение
Опция "noserverino" может решить некоторую часть проблем, связанных со "stale file handle", но стоит помнить о ее побочных эффектах, в частности, об изменении способа обработки жестких ссылок и о потенциальных проблемах с масштабируемостью. Рекомендуется обращаться к профессионалам для проведения тщательного тестирования с этой опцией, особенно если вы планируете ее применять в крупной производственной среде.
Это обеспечит уверенность в стабильности вашей системы и поможет избежать неожиданностей в будущем.