Что-то быстрее, чем HttpHandlers?
Какой самый быстрый способ выполнить метод на веб-сайте ASP.NET?
Сценарий довольно прост: у меня есть метод, который должен выполняться при нажатии на веб-страницу. На странице больше ничего не происходит, единственный вывод - это сообщение "сделано". Я хочу, чтобы обработка была максимально быстрой.
Каждый удар уникален, поэтому кэширование не вариант.
Я планирую использовать HttpHandler и настроить его в web.config (mypage.ashx), а не на обычной странице.aspx. Это должно значительно снизить накладные расходы.
Так что мой вопрос на самом деле: есть ли более быстрый способ сделать это, чем с помощью HttpHandlers?
3 ответа
В зависимости от того, что вы делаете, я бы не ожидал увидеть много улучшений по сравнению с использованием HttpHandler. Я бы начал с написания HttpHandler и наблюдения за его работой. Если вам нужно, чтобы это было быстрее, попробуйте более внимательно взглянуть на то, что вы на самом деле делаете во время обработки запроса, и посмотрите, что можно оптимизировать. Например, если вы ведете какую-либо запись в базу данных, попробуйте выполнить запись в локальную базу данных, а не по сети. Если это все еще не достаточно быстро, то, возможно, посмотрите на написание чего-то более низкого уровня. Впрочем, до этого момента я буду придерживаться того, что вам легче всего написать.
Для справки я написал рекламный сервер в ASP.NET (с использованием HttpHandlers), который может показывать рекламу (включая таргетинг и запись показа в локальную базу данных) за 0-15 мс под нагрузкой. Я думал, что делал довольно много обработки - но это довольно хорошее время отклика ИМХО.
Обновление через несколько месяцев:
Если вы очистите все модули HttpModules, включенные по умолчанию, это приведет к значительному снижению накладных расходов. По умолчанию следующие модули Http включены в каждый сайт через файл web.config машинного уровня:
- OutputCache
- Сеанс (для состояния сеанса)
- WindowsAuthentication
- FormsAuthentication
- PassportAuthentication
- RoleManager
- UrlAuthorization
- FileAuthorization
- AnonymousIdentification
- Профиль
- ErrorHandler
- ServiceModel
Как я уже говорил выше, мой рекламный сервер не использует ничего из этого, поэтому я только что сделал это в web.config этого приложения:
<httpModules>
<clear />
</httpModules>
Если вам нужны некоторые из них, но не все, вы можете удалить те, которые вам не нужны:
<httpModules>
<remove name="PassportAuthentication" />
<remove name="Session" />
</httpModules>
ASP.NET MVC Примечание. ASP.NET MVC требует наличия модуля состояния сеанса, если вы не предпримете что-то конкретное для его обхода. Посмотрите этот вопрос для получения дополнительной информации: Как я могу отключить состояние сеанса в ASP.NET MVC?
Обновление для IIS7: К сожалению, в IIS7 все не так просто. Вот как очистить HTTP-модули в IIS7
Я не уверен, каков ваш точный сценарий, но если вся ваша страница обрабатывает некоторые данные, вам вообще не нужна страница aspx или обработчик http. Вы можете написать веб-службу ASMX или службу WCF, чтобы делать то, что вам нужно, и это, скорее всего, будет меньше накладных расходов. Служба WCF даже не должна размещаться в ASP.NET. Вы можете разместить его в службе Windows или в консольном приложении и вызывать его in-proc, используя именованные каналы. Это, вероятно, позволило бы значительно сократить накладные расходы на вызов кода обработки данных.
Если вам действительно нужно использовать asp.net, вы также можете просто подключиться к шагу AuthorizeRequest и перехватить запрос оттуда, выполнить обработку и написать свой ответ Done напрямую.