- •Содержание
- •Раздел 1 6
- •Раздел 2 12
- •Раздел 3 19
- •Введение
- •Раздел 1 растровые изображения и задачи обеспечения авторского права
- •Сущность понятия растрового изображения.
- •Задачи обеспечения авторского права.
- •Раздел 2 технологии защиты авторского права
- •Правовые аспекты защиты авторского права.
- •Технические средства защиты авторских прав.
- •Раздел 3 теоретические основы систем испльзующиеся для будещей модели.
- •2. Модульная архитектура Apache
- •3. Базовые концепции и структуры
- •4. Обработка запросов
- •5. Фильтры
- •Заключение
- •Программы, поддерживающие exif[править | править вики-текст]
- •Microsoft Windows[править | править вики-текст]
2. Модульная архитектура Apache
Ядро Apache включает в себя основные функциональные возможности, такие как обработка конфигурационных файлов, протокол HTTP и система загрузки модулей. Ядро (в отличие от модулей) полностью разрабатывается Apache Software Foundation, без участия сторонних программистов. Запускается Apache от рутового пользователя, а все последующие операции выполняет от лица непривилегированного пользователя.
Модули представляют из себя код, расширяющий функционал Apache. Модули могут быть статически слинкованы с ядром, либо загружаться динамически. В первом случае они собираются на этапе компиляции самого Apache. Во втором случае они загружаются при загрузке Apache, для этого есть дополнительный встроенный модуль mod_so.
Кроме того, имеется набор библиотек — Apache Portable Runtime (APR), который реализует кросс-платформенную поддержку системных функций.
Специальный модуль системного уровня — Multi-Processing Module (MPM) — дает возможность оптимизировать Apache в условиях конкретной операционной системы, предоставляя еще один вариант доступа к системным сервисам.
После стартовой начальной инициализации ядро передает управление модулю MPM, который поддерживает пул рабочих процессов/потоков, реализует интерфейс между сервером и данной операционной системой, оптимизируя работу сервера. MPM появился тогда, когда Apache был перенесен на Windows.
MPM имеет 2 основных режима работы:
Prefork — это традиционный non-threaded вариант, присущий версии 1.3.
Worker — многопоточный вариант, которому присущ меньший расход памяти.
Модуль взаимодействует с ядром с помощью простого интерфейса: в ядре регистрируется обработчик (handler), который потом может быть вызван. Также модуль может взаимодействовать с ядром с помощью специальных Apache API, которые позволяют модулям работать со структурами данных ядра.
Существует 4 основных типа обработчиков:
Обработчики-переключатели.
Конфигурационные обработчики.
Фильтры.
Функции-опции.
Обработчики-переключатели занимаются переключением обработчиков, выполняя роль событийного триггера. Такой обработчик имеет префикс ap_run_HOOKNAME. Они бывают двух типов:
RUN_ALL/VOID — вызываются всегда, независимо от статуса выполняемой задачи;
RUN_FIRST — вызываются до тех пор, пока задача не выполнена.
Модуль регистрирует в первую очередь обработчики этого типа. Вообще регистрация обработчиков отличается в первом и во втором Apache. В первом все обработчики регистрируются автоматически при старте. Во втором модуль регистрирует 4 обработчика-переключателя, остальные регистрируются потом с помощью функции ap_run_xxx.
Порядок, в котором вызываются переключатели, для первого Apache тот же, в котором они регистрируются. Во втором Apache механизм изменился: вызов ap_hook_xxx может изменить порядок регистрируемого переключателя. Каждый модуль может определить собственный набор конфигурационных директив. Конфигурационные обработчики выделяют память для чтения таких директив и определяют, что с ними делать.
Фильтры и функции-опции появились во втором Apache. Функции-опции похожи на обработчики.
В начало
