I am batch uploading products to a database.
I am download the image urls to the site to be used for the products.
The code I written works fine for the first 25 iterations (always that number for some reason), but then throws me a System.Net.WebException “The operation has timed out”.
if (!File.Exists(localFilename))
{
using (WebClient Client = new WebClient())
{
Client.DownloadFile(remoteFilename, localFilename);
}
}
I checked the remote url it was requesting and it is a valid image url that returns an image.
Also, when I step through it with the debugger, I don’t get the timeout error.
HELP! 😉
If I were in your shoes, here’s a few possibilities I’d investigate:
My money is on the latter one, since the fact that it always breaks at a nice round number of requests, and that stepping in the debugger (aka slower!) doesn’t trigger the problem.
To test all this, I’d start with the easy thing: stick in a delay (Thread.Sleep) before each HTTP call, and see if the problem goes away. If it does, reduce the delay until the problem comes back. If it doesn’t, increase the delay up to a large number (e.g. 10 seconds) until the problem goes away. If it doesn’t go away with a 10 second delay, that’s truly a mystery and I’d need more info to diagnose.
If it does go away with a delay, then you need to figure out why– and whether the limit is permanent (e.g. server’s firewall which you can’t change) or something you can change. To get more info, you’ll want to time the requests (e.g. check DateTime.Now before and after each call) to see if you see a pattern. If the timings are all consistent and suddenly get huge, that suggests a network/firewall/proxy throttling. If the timings gradually increase, that suggests a server you’re gradually overloading and lengthening its request queue.
In addition to timing the requests, I’d set the timeout of your webclient calls to be longer, so you can figure out if the timeout is infinite or just a bit longer than the default. To do this, you’ll need an alternative to the WebClient class, since it doesn’t support a timeout. This thread on MSDN Forums has a reasonable alternative code sample.
An alternative to adding timing in your code is to use Fiddler: