メールを送信する小さなメールワーカーを構築しようとしています。電子メール ワーカーは独自のスレッドで動作します。global.asax はスレッドを開始し、この例外をスローする前に 1 ラウンド実行します。投げる場所を調べてみたのですが、毎回違うようです。レコードはテキスト ファイルに出力されるので、おそらく破棄機能でしょうか?
これはスローされる例外です:
電子メール ワーカーの for ループで新しいラウンドを開始する 電子メール ワーカーの for ループ
でスリープ状態になる
mscorlib.dll で「System.Threading.ThreadAbortException」タイプの最初の例外が発生しまし
た 「System.Threading.ThreadAbortException」タイプの例外が発生しましたmscorlib.dll で発生しましたが、ユーザー コードでは処理されませんでした
これは EmailWorker のコードです
public static class EmailWorker
{
public static void Work()
{
TimeSpan sleepTime = new TimeSpan(0, 1, 0);
for (; ; )
{
Debug.WriteLine("Starting a new round in the email worker for-loop");
try
{
// Get the records
CS_Code.UtopiaDataContext db = new CS_Code.UtopiaDataContext();
List<CS_Code.Global_Email> emailsToSend = (from xx in db.Global_Emails select xx).ToList();
// Write the records to a file (for now)
TextWriter writer = new StreamWriter(@"test.txt", true); // For debugging
foreach (var email in emailsToSend)
writer.WriteLine("To: " + email.Email_Address + ", Subject: " + email.Subject + ", uid:" + email.UserName.ToString());
writer.Close();
writer.Dispose();
// Delete the used records from the database
foreach (var email in emailsToSend)
db.Global_Emails.DeleteOnSubmit(email);
db.SubmitChanges();
db.Dispose();
Debug.WriteLine("Going to sleep in the email worker for-loop");
Thread.Sleep(sleepTime); // Sleep for 1 minute.
Debug.WriteLine("Just woke up in the email worker for-loop");
}
catch (Exception e)
{
Debug.WriteLine(e.Message);
break;
}
}
}
}
これは、すべてを開始する global.asax ファイルです。
private static Thread EmailWorkerThread { get; set; }
void Application_Start(object sender, EventArgs e)
{
// Email worker thread
if ((EmailWorkerThread == null) || (!EmailWorkerThread.IsAlive))
{
ThreadStart ts = new ThreadStart(EmailWorker.Work);
EmailWorkerThread = new Thread(ts);
EmailWorkerThread.Start();
}
}
void Application_End(object sender, EventArgs e)
{
// Email worker thread
if ((EmailWorkerThread != null) || (EmailWorkerThread.IsAlive))
EmailWorkerThread.Abort();
EmailWorkerThread = null;
}