Delphi: Почему IdHTTP.ConnectTimeout делает запросы медленнее?
Я обнаружил, что при установке свойства ConnectTimeoout для компонента TIdHTTP, это делает запросы (GET и POST) примерно на 120 мс медленнее?
Почему это, и могу ли я как-то избежать / обойти это?
Конверт: D2010 с поставляемыми компонентами Indy, все обновления установлены для D2010. ОС WinXP (32bit) SP3 с большинством патчей...
Мой график времени:
Procedure DoGet;
Var
Freq,T1,T2 : Int64;
Cli : TIdHTTP;
S : String;
begin
QueryPerformanceFrequency(Freq);
Try
QueryPerformanceCounter(T1);
Cli := TIdHTTP.Create( NIL );
Cli.ConnectTimeout := 1000; // without this we get < 15ms!!
S := Cli.Get('http://127.0.0.1/empty_page.php');
Finally
FreeAndNil(Cli);
QueryPerformanceCounter(T2);
End;
Memo1.Lines.Add('Time = '+FormatFloat('0.000',(T2-T1)/Freq) );
End;
Когда ConnectTimeout установлен в коде, я получаю среднее значение. время 130-140мс, без 5-15мс...
1 ответ
Когда ConnectTimeout
ноль (и TIdAntifreeze
не действует), Indy просто подключается. Иначе, TIdIOHandlerStack.ConnectClient
звонки DoConnectTimeout
, который создает новый поток для соединения, пока вызывающий поток спит и обрабатывает TIdAntifreeze
операции, ожидающие установления соединения. Если к моменту истечения времени ожидания соединения нет, оно вызывает исключение.
Потоки не свободны, и вызывающий поток всегда будет в спящем режиме, прежде чем проверять, выполнил ли поток подключения свою задачу. Продолжительность сна по умолчанию составляет 125 мс. (Чтобы использовать что-то еще, активируйте TIdAntifreeze
и установить его IdleTimeout
свойство ниже 125.)