
- •Управление распределенными ресурсами План
- •2. Распределенные файловые системы
- •2.1. Файловая система
- •2.2. Файловая система ос
- •2.3. Интерфейс файлового сервиса
- •Операционные системы персональных компьютеров
- •Серверные операционные системы
- •2.4. Интерфейс сервиса каталогов
- •2.5. Семантика разделения файлов
- •3. Операционная система Unix
- •4. Вопросы разработки структуры файловой системы
- •5. Кэширование
- •Кэш-память Внешняя память
- •Назначение кеш памяти
- •6. Репликация
- •7. Распределенные файловые системы
- •7.2. Сетевая файловая система (nfs) и файл /etc/exports
2.2. Файловая система ос
Файловая система - это часть операционной системы, назначение которой состоит в том, чтобы:
1. обеспечить пользователю удобный интерфейс при работе с данными, хранящимися на диске,
2. и обеспечить совместное использование файлов несколькими пользователями и процессами.
В широком смысле понятие "файловая система" включает:
совокупность всех файлов на диске,
наборы структур данных, используемых для управления файлами, такие, например, как каталоги файлов, дескрипторы файлов, таблицы распределения свободного и занятого пространства на диске,
комплекс системных программных средств, реализующих управление файлами, в частности: создание, уничтожение, чтение, запись, именование, поиск и другие операции над файлами.
Ключевым компонентом любой распределенной системы является файловая система.
Как и в централизованных системах, в распределенной системе функцией файловой системы является хранение программ и данных и предоставление доступа к ним по мере необходимости.
Файловая система поддерживается одной или более машинами, называемыми файл-серверами.
Файл-серверы перехватывают запросы на чтение или запись файлов, поступающие от других машин (не серверов). Эти другие машины называются клиентами. Каждый посланный запрос проверяется и выполняется, а ответ отсылается обратно.
Файл-серверы обычно содержат иерархические файловые системы, каждая из которых имеет корневой каталог и каталоги более низких уровней. Рабочая станция может подсоединять и монтировать эти файловые системы к своим локальным файловым системам. При этом монтируемые файловые системы остаются на серверах.
Важно понимать различие между файловым сервисом и файловым сервером.
Файловый сервис - это описание функций, которые файловая система предлагает своим пользователям. Это описание включает имеющиеся примитивы, их параметры и функции, которые они выполняют. С точки зрения пользователей файловый сервис определяет то, с чем пользователи могут работать, но ничего не говорит о том, как все это реализовано.
В сущности, файловый сервис определяет интерфейс файловой системы с клиентами.
Файловый сервер - это процесс, который выполняется на отдельной машине и помогает реализовывать файловый сервис.
В системе может быть один файловый сервер или несколько, но в хорошо организованной распределенной системе пользователи не знают, как реализована файловая система. В частности, они не знают количество файловых серверов, их месторасположение и функции. Они только знают, что если процедура определена в файловом сервисе, то требуемая работа каким-то образом выполняется, и им возвращаются требуемые результаты. Более того, пользователи даже не должны знать, что файловый сервис является распределенным. В идеале он должен выглядеть также, как и в централизованной файловой системе.
Так как обычно файловый сервер - это просто пользовательский процесс (или иногда процесс ядра), выполняющийся на некоторой машине, в системе может быть несколько файловых серверов, каждый из которых предлагает различный файловый сервис.
Например, в распределенной системе может быть два сервера, которые обеспечивают файловые сервисы систем UNIX и MS-DOS соответственно, и любой пользовательский процесс пользуется подходящим сервисом.
Файловый сервис в распределенных файловых системах (впрочем как и в централизованных) имеет две функционально различные части:
собственно файловый сервис
и сервис каталогов.
Файловый сервис имеет дело с операциями над отдельными файлами, такими, как чтение, запись или добавление.
Сервис каталогов имеет дело с созданием каталогов и управлением ими, добавлением и удалением файлов из каталогов и т.п.