У меня есть небольшое приложение, которое использует WCF для связи с веб-сервером. Эта программа используется примерно 200 клиентами, и каждый клиент отправляет около 5-20 запросов/мин.Время ожидания ответа на запрос
Глядя на журналы ошибок, я часто получаю:
канал запроса истекло время ожидания ответа после 00: 00: 59,9989999
Запросы выполняются следующим образом:
ClientService Client = new ClientService();
Client.Open();
Client.updateOnline(userID);
Client.Close();
Это app.config
<configuration>
<configSections>
</configSections>
<startup><supportedRuntime version="v2.0.50727"/></startup><system.serviceModel>
<bindings>
<wsHttpBinding>
<binding name="WSHttpBinding_IClientService" closeTimeout="00:01:00"
openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard"
maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8" useDefaultWebProxy="true"
allowCookies="false">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<reliableSession ordered="true" inactivityTimeout="00:10:00"
enabled="false" />
<security mode="None">
<transport clientCredentialType="Windows" proxyCredentialType="None"
realm="" />
<message clientCredentialType="Windows" negotiateServiceCredential="true" />
</security>
</binding>
</wsHttpBinding>
</bindings>
<client>
<endpoint address="PATH TO SERVICE"
binding="wsHttpBinding" bindingConfiguration="WSHttpBinding_IClientService"
contract="IClientService" name="WSHttpBinding_IClientService">
<identity>
<dns value="localhost" />
</identity>
</endpoint>
</client>
</system.serviceModel>
Из "много звонков" каждый день около 200-800 неудачу. И о n-1 в порядке. Я очень смущен тем, что может быть проблемой. Глядя на статистику сервера, он вряд ли наращивает пот - каждый запрос принимает < 2 секунды для обработки. Передаваемые данные состоят из «int» или «очень маленьких строк» - поэтому, если это не так, то должен быть последовательный отказ.
Предложения?
Вы эта службы в IIS или оно организовано с помощью службы Windows или какого-либо другого приложения? –
Вы пытались играть с настройками таймаута и цитаты в файле конфигурации? – eulerfx
На самом деле, я предлагаю включить трассировку WCF (как описано здесь: http://msdn.microsoft.com/en-us/library/ms733025.aspx) и просмотреть сообщения, которые регистрируются при появлении этих ошибок. –