У меня есть приложение ASP.NET 4.0, работающее поверх IIS 7.5 на 64-битной машине Windows Server 2008 R2 Enterprise с огромным количеством ОЗУ, ЦП, диска и т. Д.
С каждым веб-запросом приложение ASP.NET подключается к серверной веб-службе (через необработанные сокеты), которая работает на том же компьютере.
Проблема: похоже, что-то ограничивает количество одновременных подключений к серверной веб-службе. Подозрительно, но количество одновременных подключений достигает 16.
Я нашел эту ключевую статью от Microsoft, в которой объясняется, как настроить параметры IIS для размещения приложений ASP.NET, которые делают множество запросов веб-служб: http://support.microsoft.com/?id=821268#tocHeadRef
Я следил за рекомендациями статьи, но все равно не повезло. Настройка, которая особенно интересна, - это maxconnection
настройка, которую я даже повысил до 999.
Есть идеи, что еще может дросселировать соединения?
Примечание. Когда я исключил IIS из смеси и заставил клиентов подключаться напрямую к серверной веб-службе, она с радостью откроет столько соединений, сколько мне нужно, поэтому я уверен, что серверная часть не является узким местом. Это должно быть что-то в области IIS / ASP.NET.
Вот соответствующий раздел, machine.config
который, я уверен, читается приложением (проверено appcmd.exe
):
<system.web>
<processModel autoConfig="false" maxWorkerThreads="100" maxIoThreads="100" minWorkerThreads="50" />
<httpRuntime minFreeThreads="176" minLocalRequestFreeThreads="152"/>
<httpHandlers />
<membership>
<providers>
<add name="AspNetSqlMembershipProvider"
type="System.Web.Security.SqlMembershipProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a"
connectionStringName="LocalSqlServer"
enablePasswordRetrieval="false"
enablePasswordReset="true"
requiresQuestionAndAnswer="true"
applicationName="/"
requiresUniqueEmail="false"
passwordFormat="Hashed"
maxInvalidPasswordAttempts="5"
minRequiredPasswordLength="7"
minRequiredNonalphanumericCharacters="1"
passwordAttemptWindow="10"
passwordStrengthRegularExpression="" />
</providers>
</membership>
<profile>
<providers>
<add name="AspNetSqlProfileProvider" connectionStringName="LocalSqlServer" applicationName="/"
type="System.Web.Profile.SqlProfileProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</providers>
</profile>
<roleManager>
<providers>
<add name="AspNetSqlRoleProvider" connectionStringName="LocalSqlServer" applicationName="/"
type="System.Web.Security.SqlRoleProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
<add name="AspNetWindowsTokenRoleProvider" applicationName="/"
type="System.Web.Security.WindowsTokenRoleProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</providers>
</roleManager>
</system.web>
<system.net>
<connectionManagement>
<add address="*" maxconnection="999"/>
</connectionManagement>
</system.net>