
- •1. Управление процессами
- •1.1 Операции над процессами
- •1.2 Обработка прерываний
- •2. Иерархическая структура ос.
- •2.1 Понятие параллельных и асинхронных процессов
- •2.2 Алгоритм Деккера.
- •2.3 Аппаратная реализация взаимоисключения
- •2.4 Реализация взаимоисключения с помощью семафоров
- •3. Тупиковые ситуации
- •3.1 Четыре необходимых условия возникновения тупика
- •3.2 Основные направления исследований по проблеме тупиков
- •3.3 Предотвращение тупиков, 3 стратегических принципа.
- •3.5 Обнаружение тупиков
- •3.6 Восстановление после тупиков
- •4. Управление памятью
- •4.1 Организация памяти
- •4.2 Стратегии управления памятью
- •4.3 Связное и несвязное распределение памяти
- •4.4 Мультипрограммирование с фиксированными разделами
- •4.5 Мультипрограммирование с переменными разделами
- •4.6 Стратегии размещения информации в памяти
- •5. Организация виртуальной памяти
- •5.1 Страничная организация памяти
- •5.2 Сегментная организация памяти
- •5.3 Странично-сегментная организация памяти
- •5.4 Стратегии управления виртуальной памятью
- •5.5 Принцип локальности
- •5.6 Стратегии вталкивания страниц
- •6. Управление процессорами
- •6.1 Уровни планирования загрузки процессоров
- •6.2 Цели планирования
- •6.3 Принципы планирования
- •7 Управление внешней памятью
- •8. Производительность
- •8.1 Методы оценки производительности
- •9. Операционная система ms-dos – структура и механизмы
- •9.1 Этапы загрузки ms-dos
- •9.2 Параметры загрузки ms-dos
- •9.3 Структура диска в ms-dos
- •9.4 Использование памяти системой ms-dos
- •9.5 Средства использования памяти
- •10. Операционная система windows 9.X
- •10.1 Сравнение dos и Windows 9.X
- •10.2 Windows 9.X Функции операционной системы
- •10.3 Виртуальная адресация памяти Windows 9.X
- •10.4 Виртуальные машины ос Windows 9.X
- •10.5 Процессы и сообщения в ос Windows 9.X
- •10.6 Планирование приоритетов
- •10.7 Файловая система Windows 9.X
- •11. Операционная система unix
- •11.1 Структура ос unix
- •11.2 Файловая система ос unix
- •11.3 Типы файлов.
- •11.4 Структура файловой системы unix.
- •11.4.1 Базовая файловая система. System V (s5fs).
- •11.4.2 Файловая система ffs.
- •11.5 Архитектура виртуальной файловой системы.
- •11.6 Подсистема управления процессами
- •11.6.1 Типы процессов
- •11.6.2 Атрибуты процесса.
- •11.6.3 Состояния процесса.
- •11.7 Принципы управления памятью
- •11.8 Планирование выполнения процессов
- •11.9 Взаимодействия между процессами
- •12. Загрузка ос windows 2000
- •12.3 Загрузка и инициализация драйверов устройств
- •12.6.1 Раздел [boot loader]
- •12.6.2 Раздел [operating systems]
- •13 Файловая система windows nt (ntfs)
- •13 Новые возможности ntfs 5.0
- •14 Структура ntfs
- •14.1 Главная файловая таблица
- •14.2 Атрибуты файла ntfs
- •14.3 Системные файлы ntfs
- •14.4 Сравнение ntfs с hpfs и fat
- •15 Конфигурирование системы
11.4 Структура файловой системы unix.
Исконной файловой системой UNIX является s5fs. Файловая система FFS появилась позже, она обладает лучшей производительностью, функциональностью и надежностью. Файловые системы современных версий UNIX используют базовые идеи, заложенные в системах s5fs и FFS, которые и сегодня поддерживаются в большинстве версий UNIX.
11.4.1 Базовая файловая система. System V (s5fs).
Каждый жесткий диск состоит из одной или нескольких логических частей, называемых разделами (partitions). В UNIX разделы выступают в качестве независимых устройств, доступ к которым осуществляется как к различным носителям данных. Каждый раздел имеет свою файловую систему. Файловая система s5fs занимает раздел диска и состоит из трёх основных компонентов:
суперблок. Содержит общую информацию о файловой системе;
массив индексных дескрипторов (ilist). Содержит метаданные всех файлов файловой системы. Индексный дескриптор содержит статусную информацию о файле и указывает на расположение данных этого файла. Ядро обращается к inode по индексу в массиве ilist. Один inode является корневым (root) inode файловой системы, через него обеспечивается доступ к структуре каталогов и файлов. Размер массива ilist является фиксированным и задается при создании файловой системы. Таким образом, файловая система s5fs имеет ограничения по числу файлов, которые могут в ней храниться, независимо от размера этих файлов;
Блоки хранения данных – занимают большую часть дискового раздела, и их число определяет максимальный суммарный объем данной файловой системы. Размер блока кратен 512 битам.
Суперблок считывается в память при монтировании файловой системы и находится там до её отключения. Суперблок содержит следующую информацию:
Тип файловой системы (s_type);
Размер файловой системы в логических блоках, включая сам суперблок, ilist и блоки хранения данных (s_fsize);
Размер массива индексных дескрипторов (s_isize);
Число свободных блоков, доступных для размещения (s_tfree);
Число свободных inode, доступных для размещения (s_tinode);
Флаги (флаг модификации s_fmod, флаг режима монтирования s_fronly);
Размер логического блока (512, 1024, 2048);
Список номеров свободных inode;
Список адресов свободных блоков.
Индексные дескрипторы. Индексный дескриптор не содержит:
Имени файла, которое содержится в блоках хранения данных каталога;
Содержимого файла, которое размещено в блоках хранения данных.
При открытии файла ядро помещает копию дискового inode в память в таблицу, которая содержит несколько дополнительных полей.
Основными полями дискового inode являются следующие:
Di_mode – тип файла, дополнительные атрибуты выполнения и права доступа;
Di_nlinks – число ссылок на файл, т.е. количество имён, которые имеет файл в файловой системе;
Di_uid, di_gid – идентификаторы владельца-пользователя и владельца-группы;
Di_size – размер файла в байтах;
Di_atime – время последнего доступа к файлу;
Di_mtime – время последней модификации;
Di_ctime – время последней модификации inode кроме полей di_atime, di_mtime;
Di_addr[13] – массив адресов дисковых блоков хранения данных.
Индексный дескриптор содержит информацию о расположении данных файла. Эта информация хранится в виде массива, каждый элемент которого содержит физический адрес дискового блока, а индексом массива является номер логического блока файла. Массив имеет фиксированный размер и состоит из 13 элементов. При этом первые 10 адресуют непосредственно блоки хранения данных файла. Одиннадцатый элемент адресует блок, в свою очередь содержащий адрес блоков хранения данных. Двенадцатый элемент указывает на дисковый блок, также хранящий адреса блоков, каждый из которых адресует блок хранения данных файла. Тринадцатый элемент используется для тройной косвенной адресации, когда для нахождения адреса блока хранения данных файла используется три дополнительных блока.
Такой подход позволяет поддерживать работу с файлами с размером до десятка мегабайт. Для относительно небольших файлов (до 10 Кбайт при размере блока 1024 байт) используется прямая индексация, обеспечивающая максимальную производительность.
Для файлов размер которых не превышает 266 Кбайт (10 Кбайт + 256*1024), достаточно простой косвенно адресации. При использовании тройной косвенной адресации можно обеспечить доступ к 16 777 216 блокам (256*256*256).