Я написал простое консольное приложение, чтобы проверить и проверить, работает ли мой сайт, проверив ссылку, которая всегда работает. Проблема была в том, что он вышел на днях и не уведомил меня, у него была ошибка:
system.net.webexception, время операции истекло
system.net.httpwebrequest.getresponse
Я установил таймаут как 15000 миллисекунд, то есть 15 секунд. Я смотрю на firebug, когда он запрашивал, и он сказал, что запрос был прерван, я не смог увидеть код состояния. Но мне интересно, почему я получаю это ожидание, когда устанавливаю тайм-аут?
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net.Mail;
using System.Net;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
WebRequest request = WebRequest.Create("http://MYSITE.com/A/P/LIB/22?encoding=UTF-8&b=100");
request.Timeout = 15000;
SmtpClient mailserver = null;
try
{
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
if (response == null || response.StatusCode != HttpStatusCode.OK)
{
MailMessage contactMsg = new MailMessage();
contactMsg.To.Add(new MailAddress("abc123@mysite.com"));
contactMsg.From = new MailAddress("donotreply@mysite.com");
contactMsg.Subject = "Site is not responding!";
contactMsg.IsBodyHtml = true;
contactMsg.Body = "<html><body><h1>The Site is not responding</h1> " +
"Please check the server. <br /><br />Thank You</body></html>";
mailserver = new SmtpClient("smtp.mysite.com", 25);
//Setup email message
try
{
mailserver.Send(contactMsg);
mailserver.Dispose();
}
catch (Exception exc)
{
Console.WriteLine(exc.ToString());
mailserver.Dispose();
}
Console.WriteLine("Site is Down!");
}
else
{
Console.WriteLine("Site is Up!");
}
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
mailserver.Dispose();
}
}
}
}