В чем разница между «классическим» и «интегрированным» конвейерным режимом в IIS7?

491

Вчера вечером я развертывал приложение ASP.NET MVC и обнаружил, что развертывание IIS7 в интегрированном режиме требует меньше усилий. У меня вопрос в чем разница? И каковы последствия использования одного или другого?

Джон Эриксон
источник
10
Как это было меньше работы для развертывания с интегрированным режимом против классического? Просто любопытно
Питер Лиллевольд
9
@Peter: URL-адреса без расширений требуют сопоставления вручную в классическом режиме.
Мехрдад Афшари
2
даже в MVC Global.asax примечания гласят: Инструкции по включению классического режима IIS6 или IIS7 см . на веб-сайте go.microsoft.com/?LinkId=9394801 . Или вы можете просто включить интегрированный режим и включить сборку System.Web.Mvc, и все просто работает.
Джон Эриксон

Ответы:

643

Классический режим (единственный режим в IIS6 и ниже) - это режим, в котором IIS работает только с расширениями ISAPI и фильтрами ISAPI напрямую. Фактически, в этом режиме ASP.NET является просто расширением ISAPI (aspnet_isapi.dll) и фильтром ISAPI (aspnet_filter.dll). IIS просто рассматривает ASP.NET как внешний плагин, реализованный в ISAPI, и работает с ним как с черным ящиком (и только тогда, когда ему нужно передать запрос в ASP.NET). В этом режиме ASP.NET не сильно отличается от PHP или других технологий для IIS.

Интегрированный режим, с другой стороны, является новым режимом в IIS7, где конвейер IIS тесно интегрирован (то есть точно такой же) с конвейером запросов ASP.NET. ASP.NET может видеть каждый запрос и манипулировать им по пути. ASP.NET больше не рассматривается как внешний плагин. Он полностью смешан и интегрирован в IIS. В этом режиме ASP.NET в HttpModuleосновном обладают почти такой же мощью, как и фильтр ISAPI, а ASP.NET HttpHandlerмогут иметь почти такую ​​же возможность, как расширение ISAPI. В этом режиме ASP.NET в основном является частью IIS.

Мехрдад Афшари
источник
8
интегрируется медленнее, чем классический?
Алекс Ноласко
Я не уверен, правильно ли говорить, что asp.net является частью IIS. Они выглядят как отдельные (хотя и интегрированные) продукты. Я могу ошибаться.
Андрей Савиных
@MehrdadAfshari Имеет ли работа с HttpModulesметодами / событиями в iis7больше функциональности, чем в iis6? Вы можете уточнить это?
Рой Намир
И добавим, что в режиме Integrated Pipeline каждый этап в конвейере запросов отображается как событие, в котором отображение обработчиков может быть переопределено в приложении. Например, можно определить встроенный ресурс HttpHandler для определенных типов маршрутов и сопоставить их с вашим пользовательским обработчиком через обработчик маршрута.
Рен
1
Идеальный ответ на такой вопрос, по крайней мере, следует обратиться к одной из статей Microsoft, таких как iis.net/learn/application-frameworks/… .
Лекс Ли
115

Интегрированный режим пула приложений

Когда пул приложений находится в интегрированном режиме, вы можете воспользоваться преимуществами интегрированной архитектуры обработки запросов IIS и ASP.NET. Когда рабочий процесс в пуле приложений получает запрос, запрос проходит через упорядоченный список событий. Каждое событие вызывает необходимые собственные и управляемые модули для обработки частей запроса и генерации ответа.

Есть несколько преимуществ для запуска пулов приложений в интегрированном режиме. Сначала модели обработки запросов IIS и ASP.NET интегрируются в единую модель процесса. Эта модель исключает шаги, которые ранее дублировались в IIS и ASP.NET, такие как проверка подлинности. Кроме того, интегрированный режим обеспечивает доступность управляемых функций для всех типов контента.

Классический режим пула приложений

Когда пул приложений находится в классическом режиме, IIS 7.0 обрабатывает запросы, как в режиме изоляции рабочих процессов IIS 6.0. Сначала запросы ASP.NET проходят собственные этапы обработки в IIS, а затем направляются в Aspnet_isapi.dll для обработки управляемого кода в управляемой среде выполнения. Наконец, запрос направляется обратно через IIS для отправки ответа.

Такое разделение моделей обработки запросов IIS и ASP.NET приводит к дублированию некоторых этапов обработки, таких как аутентификация и авторизация. Кроме того, функции управляемого кода, такие как проверка подлинности форм, доступны только для приложений ASP.NET или приложений, для которых сценарий сопоставил все запросы, которые будут обрабатываться aspnet_isapi.dll.

Обязательно протестируйте существующие приложения на совместимость в интегрированном режиме перед обновлением производственной среды до IIS 7.0 и назначением приложений для пулов приложений в интегрированном режиме. Добавлять приложение в пул приложений в классическом режиме можно только в том случае, если приложение не работает в интегрированном режиме. Например, ваше приложение может полагаться на токен аутентификации, передаваемый из IIS в управляемую среду выполнения, и, благодаря новой архитектуре в IIS 7.0, процесс нарушает работу вашего приложения.

Взято из: В чем разница между DefaultAppPool и Classic .NET AppPool в IIS7?

Первоначальный источник: Введение в архитектуру IIS

BrainCoder
источник
28
Ключевое предложение в последнем абзаце: «Вы должны добавлять приложение в пул приложений только в классическом режиме, если приложение не работает в интегрированном режиме».
DavidRR
6
@JsonStatham - Одна из причин этого заключается в том, что в интегрированном режиме нельзя использовать олицетворение ASP.NET (Сайты> Ваш сайт> IIS> Аутентификация). Если у вас есть сайт в интрасети и вы используете проверку подлинности Windows, это важное соображение. ссылка
user3308241
11

IIS 6.0 и предыдущие версии:

ASP.NET интегрировался с IIS через расширение ISAPI, C API (API, основанный на языке программирования C) и предоставил свою собственную модель обработки приложений и запросов.

Это эффективно выявило два отдельных конвейера сервера (запрос / ответ), один для собственных фильтров ISAPI и компонентов расширения, а другой для компонентов управляемого приложения. Компоненты ASP.NET будут выполняться полностью внутри пузыря расширения ISAPI ASP.NET И ТОЛЬКО для запросов, сопоставленных с ASP.NET в конфигурации сопоставления сценариев IIS.

Запросы к типам содержимого, не относящимся к ASP.NET: - изображения, текстовые файлы, HTML-страницы и ASP-страницы без сценариев обрабатывались IIS или другими расширениями ISAPI и НЕ были видны ASP.NET.

Основным ограничением этой модели было то, что службы, предоставляемые модулями ASP.NET и пользовательским кодом приложения ASP.NET, НЕ были доступны для запросов не ASP.NET

Что такое КАРТА СКРИПТА?

Карты сценариев используются для связи расширений файлов с обработчиком ISAPI, который выполняется при запросе файлов этого типа. Карта сценариев также имеет необязательный параметр, который проверяет, существует ли физический файл, связанный с запросом, прежде чем разрешить обработку запроса.

Хорошим примером может быть seen here

IIS 7 и выше

IIS 7.0 и выше были переработаны с нуля, чтобы обеспечить совершенно новый ISAPI на основе C ++ API.

IIS 7.0 и выше интегрирует среду выполнения ASP.NET с основными функциями веб-сервера, обеспечивая унифицированный (единый) конвейер обработки запросов, который доступен как для собственных, так и для управляемых компонентов, известных как модули (IHttpModules)

Это означает, что IIS 7 обрабатывает запросы, поступающие для любого типа контента, NON ASP.NET Modules / native IIS modulesи ASP.NET modulesобеспечивает обработку запросов на всех этапах. Это является причиной, по которой типы контента NON ASP.NET (.html, статические файлы) могут обрабатываться модулями .NET. ,

  • Вы можете создавать новые управляемые модули ( IHttpModule), которые могут выполняться для всего содержимого приложения и которые предоставляют вашему приложению расширенный набор служб обработки запросов.
  • Добавить новые управляемые обработчики ( IHttpHandler)
RC
источник
5

В классическом режиме IIS работает с расширениями ISAPI и фильтрами ISAPI напрямую. И использует две конвейерные линии, одну для собственного кода и другую для управляемого кода. Вы можете просто сказать, что в классическом режиме IIS 7.x работает так же, как IIS 6, и вы не получаете дополнительных преимуществ от функций IIS 7.x.

В интегрированном режиме IIS и ASP.Net тесно связаны, а не зависят от двух DLL на Asp.net, как в классическом режиме.

Миан
источник