Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Whats the difference between HttpClient.Timeout and using the WebRequestHandler timeout properties?

I can set the timeout of my HttpClient object directly with HttpClient.Timeout but I've recently read about the WebRequestHandler class which is a derivative of HttpClientHandler.

WebRequestHandler has a ReadWriteTimeout property. How will this affect the operation of the request when used alongside HttpClient.Timeout?

like image 807
iguanaman Avatar asked Oct 11 '14 09:10

iguanaman


2 Answers

When you perform a SendAsync the HttpClient.Timeout is placed on the CancellationTokenSource. This means this timeout is for the entire async operation.

On the other hand, WebRequestHandler.ReadWriteTimeout is copied to the HttpWebRequest where it is set on the request stream both ReadTimeout and WriteTimeout. So this is more a timeout at the stream level, which is ultimately a socket level timeout.

If you set both, then if the operation takes more than HttpClient.Timeout in total it will timeout, and if a read or write from the stream takes longer than WebRequestHandler.ReadWriteTimeout it will also timeout. Though I am not sure if there is a difference in the timeout exceptions raised.

like image 122
weston Avatar answered Oct 05 '22 11:10

weston


WebRequestHandler.ReadWriteTimeout - Gets or sets a time-out in milliseconds when writing a request to or reading a response from a server.

HttpClient.Timeout - Gets or sets the TimeSpan to wait before the request times out.

Here, WebRequestHandler is a wrapper over HTTPClient WebRequestHandler derives from HttpClientHandler but adds properties that generally only are available on full .NET. To conclude, it is more on less same thing.

For more info refer this link - http://blogs.msdn.com/b/henrikn/archive/2012/08/07/httpclient-httpclienthandler-and-httpwebrequesthandler.aspx

like image 34
Arindam Nayak Avatar answered Oct 05 '22 12:10

Arindam Nayak