менеджер кэша, реализующий
кэширование диска. Исполнительная
часть, в свою очередь,
основывается на службах
нижнего уровня,
предоставляемых ядром (его
можно назвать и микроядром) NT. В
функции ядра входит:
- планирование процессов,
- обработка прерываний и
исключительных ситуаций,
- синхронизация процессоров
для многопроцессорных
систем,
- восстановление системы
после сбоев.
Ядро работает в
привилегированном режиме и
никогда не удаляется из памяти.
Обратиться к ядру можно только
посредством прерывания. Ядро
расположено над уровнем
аппаратных абстракций (Hardware
Abstraction Level HAL), который
концентрирует в одном месте
большую часть
машинно-зависимых процедур. HAL
располагается между NT executive и
аппаратным обеспечением и
скрывает от системы такие
детали, как контроллеры
прерываний, интерфейсы
ввода/вывода и механизмы
взаимодействия между
процессорами. Такое решение
позволяет легко переносить
Windows NT с одной платформы на
другую путем замены только
слоя HAL.
При создании NT разработчики
руководствовались задачами
улучшения производительности
и сетевых возможностей, а также
требованием поддержки
определенного набора
прикладных сред. Эта цель была
достигнута продуманным
разделением функций между
модулями ядра и остальными
модулями. Например, передача
данных в файловую систему и по
сети производится быстрее в
пространстве ядра, поэтому
внутри ядра NT выделены буфера
для небольших по объему (от 16 до
32 Кб) операций чтения и записи,
являющихся типичными для
приложений клиент-сервер и
распределенных приложений.
Размещение этих функций
ввода-вывода внутри ядра,
может, и портит академическую
чистоту микроядра NT, но
соответствует цели создания NT.
Защищенные подсистемы Windows NT
работают в пользовательском
режиме и создаются Windows NT во
время загрузки операционной
системы. Сразу после создания
они начинают бесконечный цикл
своего выполнения, отвечая на
сообщения, поступающие к ним от
прикладных процессов и других
подсистем. Среди защищенных
подсистем можно выделить
подкласс, называемый
подсистемами окружения.
Подсистемы окружения
реализуют интерфейсы
приложений операционной
системы (API). Другие типы
подсистем, называемые
интегральными подсистемами,
исполняют необходимые
операционной системе задачи.
Например, большая часть
системы безопасности Windows NT
реализована в виде
интегральной подсистемы,
сетевые серверы также
выполнены как интегральные
подсистемы.
Наиболее важной подсистемой
окружения является Win32 -
подсистема, которая
обеспечивает доступ для
приложений к 32-bit Windows API.
Дополнительно эта система
обеспечивает графический
интерфейс с пользователем и
управляет вводом/выводом
данных пользователя. Также
поддерживаются подсистемы POSIX,
OS/2,16-разрядная Windows и MS-DOS.
Каждая защищенная подсистема
работает в режиме
пользователя, вызывая
системный сервис NT executive для
выполнения привилегированных
действий в режиме ядра. Сетевые
серверы могут выполняться как
в режиме пользователя, так и в
режиме ядра, в зависимости от
того, как они разработаны.
Подсистемы связываются между
собой путем передачи
сообщений. Когда, например,
пользовательское приложение
вызывает какую-нибудь
API-процедуру, подсистема
окружения, обеспечивающая эту
процедуру, получает сообщение
и выполняет ее либо обращаясь к
ядру, либо посылая сообщение
другой подсистеме. После
завершения процедуры
подсистема окружения посылает
приложению сообщение,
содержащее возвращаемое
значение. Посылка сообщений и
другая деятельность
защищенных подсистем невидима
для пользователя.
Основным средством,
скрепляющим все подсистемы
Windows NT в единое целое, является
механизм вызова локальных
процедур (Local Procedure Call - LPC). LPC
представляет собой
оптимизированный вариант
более общего средства -
удаленного вызова процедур (RPC),
которое используется для связи
клиентов и серверов,
расположенных на разных
машинах сети.
Средства LPC поддерживают
несколько способов передачи
данных между клиентами и
серверами: один обычно
используется для передачи
коротких сообщений, другой -
для длинных сообщений, а третий
оптимизирован специально для
использования подсистемой Win32.
Каждая подсистема
устанавливает порт - канал
связи, посредством которого с
ней могут связываться другие
процессы. Порты реализуются
как объекты.
Windows NT использует защищенные
подсистемы для того, чтобы:
- Обеспечить несколько
программных интерфейсов
(API), по возможности не
усложняя при этом базовый
программный код (NT executive).
- Изолировать базовую
операционную систему от
изменений или расширений в
поддерживаемых API.
- Объединить часть
глобальных данных,
требующихся всем API, и в то
же время отделить данные,
использующиеся каждым
отдельным API от данных,
использующихся другими API.
- Защитить окружение
каждого API от приложений, а
также от окружений других
API, и защитить базовую
операционную систему от
различных окружений.
- Позволить операционной
системе расширяться в
будущем за счет новых API.
Таким образом, реализация
частей ОС в виде серверов,
выполняющихся в режиме
пользователя, является
важнейшей частью проекта Windows NT
и оказывает глубокое
воздействие на все
функционирование системы.
Микроядро NT служит, главным
образом, средством поддержки
для переносимой основной части
ОС - набора пользовательских
сред. Концентрация
машинно-зависимых программ
внутри микроядра делает
перенос NT на разнообразные
процессоры относительно
легким. Но в то время, как
некоторые микроядра (Mach и Chorus)
предполагается поставлять в
качестве самостоятельного
программного продукта, из
операционной системы Windows NT
ядро вряд ли может быть
вычленено для отдельного
использования. Это является
одной из причин того, что
некоторые специалисты не
считают Windows NT истинно
микроядерной ОС в том смысле, в
котором таковыми являются Mach и
Chorus. Те же критики отмечают
также, что NT не исключает, как
это положено, все надстроенные
службы из пространства ядра и
что драйверы устройств в NT по
минимуму взаимодействуют с
ядром, предпочитая работать
непосредственно с лежащим ниже
слоем аппаратной абстракции HAL.
При разработке NT важнейшим
рыночным требованием являлось
обеспечение поддержки по
крайней мере двух уже
существующих программных
интерфейсов OS/2 и POSIX, а также
возможности добавления других
API в будущем.
Заметим, что для того, чтобы
программа, написанная для
одной ОС, могла быть выполнена
в рамках другой ОС,
недостаточно лишь обеспечить
совместимость API. Кроме этого,
необходимо обеспечить ей
"родное" окружение:
структуру процесса, средства
управления памятью, средства
обработки ошибок и
исключительных ситуаций,
механизмы защиты ресурсов и
семантику файлового доступа.
Отсюда ясно, что поддержка
нескольких прикладных
программных сред является
очень сложной задачей, тесно
связанной со структурой
операционной системы. Эта
задача была успешно решена в
Windows NT, при этом в полной мере
был использован опыт
разработчиков ОС Mach из
университета Карнеги-Меллона,
которые смогли в своей
клиент-серверной реализации
UNIX'а отделить базовые
механизмы операционной
системы от серверов API
различных ОС.
Windows NT поддерживает пять
прикладных сред операционных
систем: MS-DOS, 16-разрядный Windows, OS/2
1.x, POSIX и 32-разрядный Windows (Win32).
Все пять прикладных сред
реализованы как подсистемы
окружения. Каждая работает в
собственном защищенном
пользовательском
пространстве. Подсистема Win32
обеспечивает поддержку
дисплея, клавиатуры и мыши для
четырех оставшихся подсистем.
16-битовые приложения DOS и Windows
работают на VDM (virtual DOS machines -
виртуальные машины DOS), каждая
из которых эмулирует полный 80x86
процессор с MS-DOS. В NT VDM является
приложением Win32, значит, как и
обычные модули прикладных сред
для UNIX, приложения DOS и
16-битовой Windows расположены в
слое непосредственно над
подсистемой Win32.
Подсистемы OS/2 и POSIX построены
по-другому. В качестве
полноценных подсистем NT они
могут взаимодействовать с
подсистемой Win32 для получения
доступа к вводу и выводу, но
также могут обращаться
непосредственно к
исполнительной системе NT за
другими средствами
операционной системы.
Подсистема OS/2 может выполнять
многие имеющиеся приложения OS/2
символьного режима, включая OS/2
SQL Server, и поддерживает
именованные каналы и NetBIOS.
Однако возможности
подсистемы POSIX весьма
ограничена, несмотря на
непосредственный доступ ее к
службам ядра. Приложения POSIX
должны быть откомпилированы
специально для Windows NT. NT не
поддерживает двоичный код,
предназначенный для других
POSIX-совместимых систем, таких
как UNIX. К тому же подсистема POSIX
NT не поддерживает
непосредственно печать, не
поддерживает сетевой доступ,
за исключением доступа к
удаленным файловым системам, и
не поддерживает многие
средства Win32, например,
отображение на память файлов и
графику.
Рис. 8.2. Реализация
множественных прикладных сред
в Windows NT
На рисунке 8.2 показана
структура, обеспечивающая в
Windows NT поддержку множественных
прикладных сред.
NT executive выполняет базовые
функции операционной системы и
является той основой, на
которой подсистемы окружения
реализуют поддержку своих
приложений. Все подсистемы
равноправны и могут вызвать
"родные" функции NT для
создания соответствующей
среды для своих приложений.
Каждая подсистема окружения
имеет свое представление о том,
что такое, например, процесс
или описатель файла, поэтому
структуры данных, используемые
в каждом окружении, могут не
совпадать. Следовательно, как
только подсистема Win32 передала
прикладной процесс другой
подсистеме окружения, данное
приложение становится
клиентом этой подсистемы
вплоть до завершения процесса.
При этом подсистема Win32
перенаправляет входные
сообщения от пользователя
этому приложению, а также
отображает вывод приложения на
экране.
Хотя NT и не является
полностью
объектно-ориентированной, в ее
основе лежат объекты.
Единообразная форма
именования, совместного
использования и учета
системных ресурсов, простой и
дешевый способ обеспечения
безопасности системы и ее
модификации - все эти
преимущества могут быть
достигнуты при использовании
объектной модели.
В Windows NT любой ресурс системы,
который одновременно может
быть использован более чем
одним процессом, включая файлы,
совместно используемую память
и физические устройства,
реализован в виде объекта и
управляется рядом функций.
Такой подход сокращает число
изменений, которые необходимо
внести в операционную систему
в процессе ее эксплуатации.
Если, скажем, изменилось что-то
в аппаратуре, то все, что
необходимо сделать - заменить
соответствующий объект.
Аналогично, если требуется
поддержка новых ресурсов, то
надо добавить только новый
объект, не изменяя при этом
остального кода операционной
системы.
Наиболее фундаментальное
отличие между объектом и
обыкновенной структурой
данных заключается в том, что
внутренняя структура данных
объекта скрыта от наблюдения.
Вы должны вызвать объектную
функцию для того, чтобы
получить данные из объекта или
поместить данные в объект. Вы
не можете непосредственно
изменять данные, находящиеся
внутри объекта. Это отделяет
средства реализации объекта от
кода, который только
использует его, такая техника
позволяет легко изменять в
последствии реализацию
объектов.
Группа разработчиков NT executive
решила использовать объекты
для представления системных
ресурсов, потому что объекты
обеспечивают централизованные
средства для выполнения трех
важных ( и часто утомительных)
задач ОС:
- Поддержка воспринимаемых
человеком имен системных
ресурсов;
- Разделение ресурсов и
данных между процессами;
- Защита ресурсов от
несанкционированного
доступа.
Не все структуры данных в NT
executive являются объектами.
Объектами сделаны только такие
данные, которые нужно
разделять, защищать, именовать
или делать видимыми для
программ пользовательского
режима ( с помощью системных
функций). Структуры, которые
используются только одним
компонентом executive для
выполнения внутренних функций,
не являются объектами.
Несмотря на всестороннее
использование объектов для
представления разделяемых
ресурсов, Windows NT не является
объектно-ориентированной
системой в строгом смысле.
Большая часть кода
операционной системы написана
на С с целью обеспечения
переносимости. Несмотря на то,
что С не поддерживает
непосредственно
объектно-ориенти-
рованные конструкции, такие
как динамическое связывание
типов данных, полиморфные
функции или наследование
классов, эти инструментальные
средства были использованы
из-за их широкой
распространенности.
Менеджер объектов - это
компонента NT executive, которая
ответственна за создание,
удаление, защиту и слежение за
NT-объектами. Менеджер объектов
централизует операции
управления ресурсами, которые
в противном случае будут
разбросаны по всей ОС.
Менеджер объектов NT
выполняет следующие функции:
- Выделяет память для
объекта.
- Присоединяет к объекту так
называемый дескриптор
безопасности, который
определяет, кому разрешено
использовать объект, и что
они могут с ним делать.
- Создает и манипулирует
структурой каталога
объектов, в котором
хранятся имена объектов.
- Создает описатель объекта
и возвращает его
вызывающему процессу.
Процессы пользовательского
режима, включая подсистемы
окружения, должны иметь
описатель объекта перед тем,
как их нити смогут
использовать этот объект.
Использование описателей для
работы с системными ресурсами
не является новой идеей.
Например, библиотеки С и
Паскаля (а также других языков)
возвращают описатели для
открытых файлов. Аналогично
приложения Win32 используют
различные типы описателей для
управления окнами, курсором
мыши, иконками. В обоих случаях
описатели служат косвенными
указателями на системные
ресурсы; эта косвенность
предохраняет прикладные
программы от рутинной работы
непосредственно с системными
структурами данных.
Каждый NT-объект является
объектом определенного типа.
Тип определяет данные, которые
хранит объект, и "родные"
системные функции, которые
могут к нему применяться. Для
того, чтобы управлять
различными объектами
единообразно, менеджер
объектов требует, чтобы каждый
объект содержал несколько
полей стандартной информации в
определенном месте объекта. До
тех пор, пока эти данные
имеются, менеджер объектов не
заботится о том, что еще
хранится в объекте. Каждый
объект состоит из двух частей -
заголовка объекта и тела
объекта, которые содержат
стандартные и переменные
данные объекта соответственно.
Менеджер объектов работает с
заголовком объекта, а другие
компоненты executive работают с
телами объектов тех типов,
которые они сами создают.
Заголовок объекта
используется менеджером без
учета типа объекта. В заголовке
объекта любого типа содержится
имя, каталог, дескриптор
безопасности, квоты на
использование ресурсов,
счетчик открытых описателей,
база данных открытых
описателей, признак
постоянный/временный, режим
пользователя/ядра, указатель
на тип объекта.
Кроме заголовка объекта,
каждый объект имеет тело
объекта, формат и содержание
которого уникально
определяется типом этого
объекта; у всех объектов одного
и того же типа одинаковый
формат тела. При создании
объекта исполнительная часть
может оперировать данными в
телах всех объектов этого типа.
В разных ОС процессы
реализуются по-разному. Эти
различия заключаются в том,
какими структурами данных
представлены процессы, как они
именуются, какими способами
защищены друг от друга и какие
отношения существуют между
ними. Процессы Windows NT имеют
следующие характерные
свойства:
- Процессы Windows NT
реализованы в форме
объектов, и доступ к ним
осуществляется
посредством службы
объектов.
- Процесс Windows NT имеет
многонитевую организацию.
- Как объекты-процессы, так и
объекты-нити имеют
встроенные средства
синхронизации.
- Менеджер процессов Windows NT
не поддерживает между
процессами отношений типа
"родитель-потомок".
В любой системе понятие
"процесс" включает
следующее:
- исполняемый код,
- собственное адресное
пространство, которое
представляет собой
совокупность виртуальных
адресов, которые может
использовать процесс,
- ресурсы системы, такие как
файлы, семафоры и т.п.,
которые назначены
процессу операционной
системой.
- хотя бы одну выполняемую
нить.
Адресное пространство
каждого процесса защищено от
вмешательства в него любого
другого процесса. Это
обеспечивается механизмами
виртуальной памяти.
Операционная система, конечно,
тоже защищена от прикладных
процессов. Чтобы выполнить
какую-либо процедуру ОС или
прочитать что-либо из ее
области памяти, нить должна
выполняться в режиме ядра.
Пользовательские процессы
получают доступ к функциям
ядра посредством системных
вызовов. В пользовательском
режиме выполняются не только
прикладные программы, но и
защищенные подсистемы Windows NT.
В Windows NT процесс - это просто
объект, создаваемый и
уничтожаемый менеджером
объектов. Объект-процесс, как и
другие объекты, содержит
заголовок, который создает и
инициализирует менеджер
объектов. Менеджер процессов
определяет атрибуты, хранимые
в теле объекта-процесса, а
также обеспечивает системный
сервис, который
восстанавливает и изменяет эти
атрибуты.
В число атрибутов тела
объекта-процесса входят:
- Идентификатор процесса -
уникальное значение,
которое идентифицирует
процесс в рамках
операционной системы.
- Токен доступа -
исполняемый объект,
содержащий информацию о
безопасности.
- Базовый приоритет - основа
для исполнительного
приоритета нитей процесса.
- Процессорная
совместимость - набор
процессоров, на которых
могут выполняться нити
процесса.
- Предельные значения квот -
максимальное количество
страничной и нестраничной
системной памяти,
дискового пространства,
предназначенного для
выгрузки страниц,
процессорного времени -
которые могут быть
использованы процессами
пользователя.
- Время исполнения - общее
количество времени, в
течение которого
выполняются все нити
процесса.
Напомним, что нить является
выполняемой единицей, которая
располагается в адресном
пространстве процесса и
использует ресурсы, выделенные
процессу. Подобно процессу
нить в Windows NT реализована в
форме объекта и управляется
менеджером объектов.
Объект-нить имеет следующие
атрибуты тела:
- Идентификатор клиента -
уникальное значение,
которое идентифицирует
нить при ее обращении к
серверу.
- Контекст нити - информация,
которая необходима ОС для
того, чтобы продолжить
выполнение прерванной
нити. Контекст нити
содержит текущее
состояние регистров,
стеков и индивидуальной
области памяти, которая
используется подсистемами
и библиотеками.
- Динамический приоритет -
значение приоритета нити в
данный момент.
- Базовый приоритет - нижний
предел динамического
приоритета нити.
- Процессорная
совместимость нитей -
перечень типов
процессоров, на которых
может выполняться нить.
- Время выполнения нити -
суммарное время
выполнения нити в
пользовательском режиме и
в режиме ядра, накопленное
за период существования
нити.
- Состояние предупреждения -
флаг, который показывает,
что нить должна выполнять
вызов асинхронной
процедуры.
- Счетчик приостановок -
текущее количество
приостановок выполнения
нити.
Кроме перечисленных, имеются
и некоторые другие атрибуты.
Как видно из перечня, многие
атрибуты объекта-нити
аналогичны атрибутам
объекта-процесса. Весьма
сходны и сервисные функции,
которые могут быть выполнены
над объектами-процессами и
объектами-нитями: создание,
открытие, завершение,
приостановка, запрос и
установка информации, запрос и
установка контекста и другие
функции.
В Windows NT реализована
вытесняющая многозадачность,
при которой операционная
система не ждет, когда нить
сама захочет освободить
процессор, а принудительно
снимает ее с выполнения после
того, как та израсходовала
отведенное ей время (квант), или
если в очереди готовых
появилась нить с более высоким
приоритетом. При такой
организации разделения
процессора ни одна нить не
займет процессор на очень
долгое время.
Рис. 8.3. Граф
состояний нити
В ОС Windows NT нить в ходе своего
существования может иметь одно
из шести состояний (рисунок 8.3).
Жизненный цикл нити начинается
в тот момент, когда программа
создает новую нить. Запрос
передается NT executive, менеджер
процессов выделяет память для
объекта-нити и обращается к
ядру, чтобы инициализировать
объект-нить ядра. После
инициализации нить проходит
через следующие состояния:
- Готовность. При поиске
нити на выполнение
диспетчер просматривает
только нити, находящиеся в
состоянии готовности, у
которых есть все для
выполнения, но не хватает
только процессора.
- Первоочередная
готовность (standby). Для
каждого процессора
системы выбирается одна
нить, которая будет
выполняться следующей
(самая первая нить в
очереди). Когда условия
позволяют, происходит
переключение на контекст
этой нити.
- Выполнение. Как только
происходит переключение
контекстов, нить переходит
в состояние выполнения и
находится в нем до тех пор,
пока либо ядро не вытеснит
ее из-за того, что
появилась более
приоритетная нить или
закончился квант времени,
выделенный этой нити, либо
нить завершится вообще,
либо она по собственной
инициативе перейдет в
состояние ожидания.
- Ожидание. Нить может
входить в состояние
ожидания несколькими
способами: нить по своей
инициативе ожидает
некоторый объект для того,
чтобы синхронизировать
свое выполнение;
операционная система
(например, подсистема
ввода-вывода) может
ожидать в интересах нити;
подсистема окружения
может непосредственно
заставить нить
приостановить себя. Когда
ожидание нити подойдет к
концу, она возвращается в
состояние готовности.
- Переходное состояние.
Нить входит в переходное
состояние, если она готова
к выполнению, но ресурсы,
которые ей нужны, заняты.
Например, страница,
содержащая стек нити,
может быть выгружена из
оперативной памяти на
диск. При освобождении
ресурсов нить переходит в
состояние готовности.
- Завершение. Когда
выполнение нити
закончилось, она входит в
состояние завершения.
Находясь в этом состоянии,
нить может быть либо
удалена, либо не удалена.
Это зависит от алгоритма
работы менеджера объектов,
в соответствии с которым
он и решает, когда удалять
объект. Если executive имеет
указатель на объект-нить,
то она может быть
инициализирована и
использована снова.
Диспетчер ядра использует
для определения порядка
выполнения нитей алгоритм,
основанный на приоритетах, в
соответствии с которым каждой
нити присваивается число -
приоритет, и нити с более
высоким приоритетом
выполняются раньше нитей с
меньшим приоритетом. В самом
начале нить получает приоритет
от процесса, который создает
ее. В свою очередь, процесс
получает приоритет в тот
момент, когда его создает
подсистема той или иной
прикладной среды. Значение
базового приоритета
присваивается процессу
системой по умолчанию или
системным администратором.
Нить наследует этот базовый
приоритет и может изменить его,
немного увеличив или уменьшив.
На основании получившегося в
результате приоритета,
называемого приоритетом
планирования, начинается
выполнение нити. В ходе
выполнения приоритет
планирования может меняться.
Windows NT поддерживает 32 уровня
приоритетов, разделенных на
два класса - класс реального
времени и класс переменных
приоритетов. Нити реального
времени, приоритеты которых
находятся в диапазоне от 16 до 31,
являются более приоритетными
процессами и используются для
выполнения задач, критичных ко
времени.
Каждый раз, когда необходимо
выбрать нить для выполнения,
диспетчер прежде всего
просматривает очередь готовых
нитей реального времени и
обращается к другим нитям,
только когда очередь нитей
реального времени пуста.
Большинство нитей в системе
попадают в класс нитей с
переменными приоритетами,
диапазон приоритетов которых
от 0 до 15. Этот класс имеет
название "переменные
приоритеты" потому, что
диспетчер настраивает систему,
выбирая (понижая или повышая)
приоритеты нитей этого класса.
Алгоритм планирования нитей
в Windows NT объединяет в себе обе
базовых концепции -
квантование и приоритеты. Как и
во всех других алгоритмах,
основанных на квантовании,
каждой нити назначается квант,
в течение которого она может
выполняться. Нить освобождает
процессор, если:
- блокируется, уходя в
состояние ожидания;
- завершается;
- исчерпан квант;
- в очереди готовых
появляется более
приоритетная нить.
Использование динамических
приоритетов, изменяющихся во
времени, позволяет реализовать
адаптивное планирование, при
котором не дискриминируются
интерактивные задачи, часто
выполняющие операции
ввода-вывода и
недоиспользующие выделенные
им кванты. Если нить полностью
исчерпала свой квант, то ее
приоритет понижается на
некоторую величину. В то же
время приоритет нитей, которые
перешли в состояние ожидания,
не использовав полностью
выделенный им квант,
повышается. Приоритет не
изменяется, если нить
вытеснена более приоритетной
нитью.
Для того, чтобы обеспечить
хорошее время реакции системы,
алгоритм планирования
использует наряду с
квантованием концепцию абсолютных
приоритетов. В соответствии
с этой концепцией при
появлении в очереди готовых
нитей такой, у которой
приоритет выше, чем у
выполняющейся в данный момент,
происходит смена активной нити
на нить с самым высоким
приоритетом.
В многопроцессорных системах
при диспетчеризации и
планировании нитей играет роль
их процессорная совместимость:
после того, как ядро выбрало
нить с наивысшим приоритетом,
оно проверяет, какой процессор
может выполнить данную нить и,
если атрибут нити
"процессорная
совместимость" не позволяет
нити выполняться ни на одном из
свободных процессоров, то
выбирается следующая в порядке
приоритетов нить.
Средства сетевого
взаимодействия Windows NT
направлены на реализацию
взаимодействия с
существующими типами сетей,
обеспечение возможности
загрузки и выгрузки сетевого
программного обеспечения, а
также на поддержку
распределенных приложений.
Windows NT с точки зрения
реализации сетевых средств
имеет следующие особенности:
- Встроенность на уровне
драйверов. Это свойство
обеспечивает
быстродействие.
- Открытость -
обуславливается легкостью
динамической
загрузки-выгрузки,
мультиплексируемостью
протоколов.
- Наличие RPC, именованных
конвейеров и почтовых
ящиков для поддержки
распределенных приложений
.
- Наличие дополнительных
сетевых средств,
позволяющих строить сети в
масштабах корпорации:
дополнительные средства
безопасности
централизованное
администрирование
отказоустойчивость (UPS,
зеркальные диски).
Windows NT унаследовала от своих
предшественников редиректор и
сервер, протокол верхнего
уровня SMB и транспортный
протокол NetBIOS (правда, с новым
"наполнением" - NetBEUI). Как и
в сети MS-NET редиректор
перенаправляет локальные
запросы ввода-вывода на
удаленный сервер, а сервер
принимает и обрабатывает эти
запросы.
Сначала редиректор и сервер
были написаны на ассемблере и
располагались над
существующим системным
программным обеспечением MS-DOS.
Новые редиректор и сервер
встроены в Windows NT, они не
зависят от архитектуры
аппаратных средств, на которых
работает ОС. Они написаны на С и
выполнены как загружаемые
драйверы файловой системы,
которые могут загружаться или
выгружаться в любое время. Они
также могут сосуществовать с
редиректорами и серверами
других производителей.
Реализация редиректора и
сервера как драйверов файловой
системы делают их частью NT
executive. Следовательно, они имеют
доступ к специализированным
интерфейсам, которые менеджер
ввода-вывода обеспечивает для
драйверов. Эти интерфейсы, в
свою очередь, были разработаны
с учетом нужд сетевых
компонент. Доступ к
интерфейсам драйверов плюс
возможности непосредственного
вызова кэш-менеджера дают
значительный вклад в повышение
производительности
редиректора и сервера.
Многоуровневая модель
драйверов менеджера
ввода-вывода отражает
многоуровневую модель сетевых
протоколов. Так как редиректор
и сервер являются драйверами,
то они могут быть размещены на
верхнем уровне, под которым
располагаются все необходимые
драйверы транспортных
протоколов. Такая структура
обеспечивает модульность
сетевых компонент и создает
эффективный путь от уровня
редиректора или сервера вниз к
транспортному и физическому
уровням сети.
Сетевой редиректор
обеспечивает средства,
необходимые одному компьютеру
Windows NT для доступа к файлам и
принтерам другого компьютера.
Так как он поддерживает
SMB-протокол, то он работает с
существующими серверами MS-NET и
LAN Manager, обеспечивая доступ к
системам MS-DOS, Windows и OS/2 из Windows NT.
Механизмы безопасности
обеспечивают защиту данных
Windows NT, разделяемых по сети, от
несанкционированного доступа.
Редиректор имеет одну
основную задачу: поддержку
распределенной файловой
системы, которая ведет себя
подобно локальной файловой
системе, хотя и работает через
ненадежную среду (сеть). Когда
связь отказывает, редиректор
ответственен за
восстановление соединения,
если это возможно, или же за
возврат кода ошибки, чтобы
приложение смогло повторить
операцию.
Подобно другим драйверам
файловой системы, редиректор
должен поддерживать
асинхронные операции
ввода-вывода, если они
вызываются. Когда
пользовательский запрос
является асинхронным, то
редиректор должен вернуть
управление немедленно,
независимо от того,
завершилась ли удаленная
операция ввода-вывода или нет.
При этом редиректор
выполняется в контексте этой
нити. Вызывающая нить должна
продолжить свою работу, а
редиректор должен ждать
завершения запущенной
операции. Есть два варианта
решения этой проблемы: или
редиректор сам создает новую
нить, которая будет ждать, или
он может передать эту работу
уже готовой нити, существующей
в системе. В Windows NT реализован
второй вариант.
Редиректор отправляет и
получает блоки SMB для
выполнения своей работы.
Протокол SMB является
протоколом прикладного уровня,
включающим сетевой уровень и
уровень представления.
SMB реализует:
- установление сессии,
- файловый сервис,
- сервис печати,
- сервис сообщений.
Интерфейс, в соответствии с
которым редиректор посылает
блоки SMB, называется интерфейсом
транспортных драйверов
(transport driver interface - TDI). Редиректор
вызывает функции TDI для
передачи блоков SMB различным
транспортным драйверам,
загруженным в Windows NT. Для вызова
функций TDI редиректор должен
открыть канал, называемый
виртуальной связью (virtual circuit), к
машине назначения, а затем
послать SMB-сообщение через эту
виртуальную связь. Редиректор
создает только одну
виртуальную связь для каждого
сервера, с которым соединена
система Windows NT, и
мультиплексирует через нее
запросы к этому серверу.
Транспортный уровень
определяет, каким образом
реализовать виртуальную связь,
и пересылает данные через сеть.
Как и редиректор, сервер Windows
NT на 100% совместим с
существующими SMB-протоколами
MS-NET и LAN Manager. Эта полная
совместимость позволяет
серверу обрабатывать запросы,
исходящие не только от систем
Windows NT, но и от других систем,
работающих с программным
обеспечением LAN Manager. Как и
редиректор, сервер выполнен в
виде драйвера файловой
системы.
Может показаться странным,
что сервер в соответствии с
микроядерной концепцией не
реализован как серверный
процесс. Было бы логично
ожидать, что сетевой сервер
будет функционировать как
защищенная подсистема -
процесс, чьи нити ожидают
поступления запросов по сети,
выполняют их, а затем
возвращают результаты по сети.
Этот подход, как наиболее
естественный, был тщательно
рассмотрен при проектировании
Windows NT, однако, учитывая опыт
построения сетей VAX/VMS и опыт
использования RPC, было решено
выполнить сервер как драйвер
файловой системы. Хотя сервер и
не является драйвером в
обычном смысле, и он не
управляет файловой системой на
самом деле, использование
модели драйвера обеспечивает
некоторые преимущества.
Главное из них состоит в том,
что драйвер реализован в среде
NT executive и может вызывать
кэш-менеджер NT
непосредственно, что
оптимизирует передачу данных.
Например, когда сервер
получает запрос на чтение
большого количества данных, он
вызывает кэш-менеджер для
определения места
расположения этих данных в
кэше (или для загрузки этих
данных в кэш, если их там нет) и
для фиксации данных в памяти.
Затем сервер передает данные
непосредственно из кэша в сеть,
минуя доступ к диску.
Аналогично, при запросе на
запись данных сервер вызывает
кэш-менеджер для
резервирования места для
поступающих данных. Затем
сервер пишет данные
непосредственно в кэш.
Записывая данные в кэш, сервер
возвращает управление клиенту
гораздо быстрее; затем
кэш-менеджер записывает данные
на диск в фоновом режиме
(используя страничные средства
менеджера виртуальной памяти).
Будучи драйвером файловой
системы, сервер несколько
более гибок по сравнению с его
реализацией в виде процесса.
Например, он может
регистрировать функции
завершения ввода-вывода, что
позволяет ему получать
управление немедленно после
завершения работы драйверов
нижнего уровня. Хотя сервер
Windows NT реализован как драйвер
файловой системы, другие
серверы могут быть реализованы
и как драйверы, и как серверные
процессы.
Асинхронные вызовы
обрабатываются сервером
аналогично, с использованием
пула рабочих нитей.
И редиректоры, и серверы, и
транспортные драйверы могут
быть в любое время загружены и
выгружены.
Открытая архитектура сетевых
средств Windows NT обеспечивает
работу своих рабочих станций (и
серверов) в гетерогенных сетях
не только путем предоставления
возможности динамически
загружать и выгружать сетевые
средства, но и путем
непосредственного
переключения с программных
сетевых средств,
ориентированных на
взаимодействие с одним типом
сетей, на программные средства
для другого типа сетей в ходе
работы системы. Windows NT
поддерживает переключение
программных средств на трех
уровнях:
- на уровне редиректоров -
каждый редиректор
предназначен для своего
протокола (SMP, NCP, NFS, VINES);
- на уровне драйверов
транспортных протоколов,
предоставляя для них и для
редиректоров стандартный
интерфейс TDI;
- на уровне драйверов
сетевых адаптеров - со
стандартным интерфейсом
NDIS 3.0.
Для доступа к другим типам
сетей в Windows NT, помимо
встроенного, могут загружаться
дополнительные редиректоры.
Специальные компоненты Windows NT
решают, какой редиректор
должен быть вызван для
обслуживания запроса на
удаленный ввод-вывод. За
последние десятилетия
получили распространение
различные протоколы передачи
информации по сети. И хотя Windows
NT поддерживает не все эти
протоколы, она, по крайней мере,
разрешает включать их
поддержку.
После того, как сетевой
запрос достигает редиректора,
он должен быть передан в сеть. В
традиционной системе каждый
редиректор жестко связан с
определенным транспортным
протоколом. В Windows NT поставлена
задача гибкого подключения
того или иного транспортного
протокола, в зависимости от
типа транспорта, используемого
в другой сети. Для этого во всех
редиректорах нижний уровень
должен быть написан в
соответствии с определенными
соглашениями, которые и
определяют единый программный
интерфейс, называемый интерфейсом
транспортных драйверов (TDI).
TDI позволяет редиректорам
оставаться независимым от
транспорта. Таким образом, одна
версия редиректора может
пользоваться любым
транспортным механизмом. TDI
обеспечивает набор функций,
которые редиректоры могут
использовать для пересылки
любых типов данных с помощью
транспортного уровня. TDI
поддерживает как связи с
установлением соединения
(виртуальные связи), так и связи
без установления соединения
(датаграммные связи). Хотя LAN
Manager использует связи с
установлением соединений, Novell
IPX является примером сети,
которая использует связь без
установления соединения. Microsoft
изначально обеспечивает
транспорты - NetBEUI (NetBIOS Extended User
Interface), TCP/IP, IPX/SPX, DECnet и AppleTalk.
Сетевые адаптеры
поставляются вместе с сетевыми
драйверами, которые раньше
часто были рассчитаны на
взаимодействие с определенным
типом транспортного протокола.
Так как Windows NT позволяет
загружать драйверы различных
транспортных протоколов, то
производители сетевых
адаптеров, использующие такой
подход, должны были писать
различные варианты одного и
того же драйвера, рассчитанные
на связь с разными протоколами
транспортного уровня.
Чтобы помочь производителям
избежать этого, Windows NT
обеспечивает интерфейс и
программную среду, называемые
"спецификация интерфейса
сетевого драйвера" (NDIS),
которые экранируют сетевые
драйверы от деталей различных
транспортных протоколов. Самый
верхний уровень драйвера
сетевого адаптера должен быть
написан в соответствии с
рекомендациями NDIS. В этом
случае пользователь может
работать с сетью TCP/IP и сетью
NetBEUI (или DECnet, NetWare, VINES и т.п.),
используя один сетевой адаптер
и один сетевой драйвер. Среда
NDIS использовалась в сетях LAN
Manager, но для Windows NT она была
обновлена.
Через свою нижнюю границу
драйвер сетевого адаптера
обычно взаимодействует
непосредственно с адаптером
или адаптерами, которые он
обслуживает. Драйвер сетевого
адаптера, реализованный для
среды NDIS, управляет адаптером
не непосредственно, а
использует для этого функции,
предоставляемые NDIS (например,
для запуска ввода-вывода или
обработки прерываний). Таким
образом, среда NDIS образует
некую оболочку, которая
позволяет достаточно просто
переносить драйверы сетевых
адаптеров из одной ОС в другую.
NDIS позволяет сетевым драйверам
не содержать встроенных знаний
о процессоре или операционной
системе, на которых он
работает.
Совместимость сетевых
операционных систем
предполагает использование
одинакового стека
коммуникационных протоколов, в
том числе и верхнего
прикладного уровня. Протоколы
верхнего уровня (NCP, SMB, NFS, FTP,
telnet) включают две части -
клиентскую и серверную. При
взаимодействии двух
компьютеров на каждой стороне
могут присутствовать как обе
части прикладного протокола,
так и по одной его части, в
зависимости от этого
образуется или одна, или две
пары "клиент-сервер".
Для клиентской части
протокола верхнего уровня,
реализованного в виде модуля
операционной системы,
используются разные названия -
редиректор (redirector), инициатор
запросов или запросчик (requester).
Эти компоненты получают
запросы от приложений на
доступ к удаленным ресурсам,
расположенным на серверах, и
ведут диалог с сервером в
соответствии с каким-либо
протоколом прикладного уровня.
Совокупность функций, которая
может использовать приложение
для обращения к редиректору,
называется прикладным
интерфейсом (API) редиректора.
Существующая версия Windows NT 3.51
имеет встроенную поддержку
стека протоколов Novell, а именно
протоколов IPX/SPX и клиентской
части NCP. При разработке первой
версии Windows NT 3.1 между Microsoft и
Novell существовало соглашение о
том, что редиректор,
реализующий клиентскую часть
протокола NCP, будет написан
силами сотрудников Novell и
передан Microsoft в течение 60 дней
после выпуска коммерческой
версии Windows NT 3.1. Однако первая
версия редиректора от Novell
появилась только спустя четыре
месяца и обладала
существенными ограничениями:
не поддерживался полностью API
редиректора NetWare, в частности,
поддерживались только 32-х
разрядные вызовы, что означало
невозможность работы старых 16
разрядных приложений клиента
NetWare.
Через некоторое время Microsoft
разработала свою собственную
версию редиректора для NetWare,
проведя большую работу по
освоению NCP. Этот вариант
оказался гораздо лучше, однако
и он имеет недостатки: в нем
отсутствует поддержка входных
сценариев NetWare и службы
каталогов NetWare Directory Services.
Отсутствие поддержки входных
сценариев означает, что
администратору сети будет
сложно автоматизировать
создание индивидуальной
операционной среды NetWare для
пользователей, использующих
Windows NT в качестве клиентской
машины серверов NetWare.
Организация, использующая
NetWare, может добавить Windows NT в
качестве:
- клиентской рабочей
станции,
- файлового сервера или
сервера печати наряду с
NetWare,
- файлового сервера или
сервера печати вместо NetWare,
- сервера баз данных или
других приложений.
Сеть с файловыми серверами
различных типов (NetWare и Windows NT)
порождает сложные технические
проблемы. Даже если серверы
используют одинаковые
транспортные протоколы, в
данном случае протокол IPX (в
реализации Microsoft имеющий
название NWLink), клиентским
рабочим станциям все равно
придется загружать два разных
инициатора запросов. У клиента,
работающего в среде MS-DOS, для
этого может просто не хватить
памяти.
Для смягчения перехода от
NetWare к Windows NT Server разработано
несколько инструментальных
программ, в том числе утилита
Migration Tool, которая включена в
комплект поставки Windows NT Server.
Эта утилита переносит учетную
информацию пользователей
(имена пользователей,
ограничения и права доступа) и
данные с одного или нескольких
файловых серверов NetWare на
сервер Windows NT. Migration Tool
подбирает наилучшее
соответствие между
возможностями NetWare и
возможностями Windows NT. Однако
имеется ряд существенных
различий в том, как
обрабатываются такие вещи, как
ограничения. В NetWare подобная
информация обрабатывается для
каждого пользователя в
отдельности, а в Windows NT она
общая для целого сервера.
Компания Beame and Whiteside Software
создала первый NFS сервер для
Windows NT, а также продукт под
названием BW-Multiconnect, который
превращает сервер Windows NT в
сервер NetWare. Системы Windows NT с
установленным продуктом
BW-Multiconnect посылают
широковещательные сообщения
по протоколу SAP (протокол
объявления сервисов и серверов
по сети - Service Advertising Protocol, с
помощью которого клиенты NetWare
узнают о наличии в сети
серверов и о тех услугах,
которые они предоставляют).
BW-Multiconnect должен облегчить
сосуществование и миграцию от
NetWare к Windows NT. Хотя он и может
работать как единственный
NCP-сервер сети, он не
предназначен для этой роли, так
как предоставляет лишь
ограниченный набор утилит под
Windows и DOS, и не обрабатывает
входных командных файлов NetWare.
Но когда в сети есть
"настоящий" файловый
сервер NetWare, то пользователи
могут войти в этот сервер,
выполнить системный входной
командный файл, а затем
подсоединиться к серверу Windows
NT. Этот продукт превращает в
сервер NetWare как Windows NT Server, так и
Windows NT Workstation.
Microsoft ведет работу над
созданием своих собственных
файл- и принт-серверов NetWare для
Windows NT. Кроме этого, скоро
должен появиться редиректор
NetWare для Windows NT, поддерживающий
NDS.
Рассмотренные способы
организации взаимодействия
сетей построены на
использовании принципа
мультиплексирования
протоколов. Другим подходом
является использование шлюза.
Шлюз действует как транслятор,
что позволяет получать доступ
к файлам и ресурсам печати на
файловом сервере NetWare, не
пользуясь ничем, кроме
загруженного редиректора Windows
NT. Шлюз преобразовывает
SMB-сообщения, посланные
каким-либо Windows NT-клиентом, в
NCP-сообщения, которые
посылаются на серверы NetWare. В
этом случае имеется экономия
памяти на клиентских машинах,
так как не требуется загружать
дополнительные редиректоры.
Вариант шлюза подходит
только для приложений,
использующих для запросов к
серверу NetWare только
стандартный API, а при
использовании специфического
для NetWare API нельзя обойтись без
установки дополнительного
редиректора.
Если NetWare-шлюз загружен, Windows NT
Server может подсоединиться к
одному или нескольким файловым
серверам NetWare и подключиться к
любому дисковому тому, очереди
на печать или каталогу. После
того, как сервер подключился к
ресурсам, их можно начинать
использовать совместно с
другими пользователями через
File Manager или Print manager, как если бы
они были локальными ресурсами.
То есть пользователи, вошедшие
в домен, на сервере которого
установлен шлюз к NetWare,
получают доступ к серверам
NetWare.
Трансляция протоколов в
шлюзе замедляет доступ к
серверу NetWare по сравнению с
доступом через редиректор
клиента. При тестировании
замедление в малозагруженном
шлюзе составило от 10% до 15%.
Имя пользователя,
используемое шлюзом для входа
в сервер NetWare, должно входить в
группу NTGateway на сервере Windows NT.
Разрешение на доступ к
ресурсам NetWare предоставляется
пользователям сервером Windows NT
точно так же, как если бы это
были его локальные ресурсы.
Предыдущая
глава || Оглавление
|| Следующая глава