Что-то быстрее, чем 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 напрямую.

Другие вопросы по тегам