利用Timer在ASP.NET中實現(xiàn)計劃任務的方法
更新時間:2007年04月13日 00:00:00 作者:
.NET Framework中為我們提供了3種類型的Timer,分別是:
Server Timer(System.Timers.Timer),Thread Timer(System.Threading.Timer )和Windows Timer(System.Windows.Forms.Timer)。
其中Windows Timer和WinAPI中的Timer一樣,是基于消息的,而且是單線程的。另外兩個Timer則不同于Windows Timer,它們是基于ThreadPool的,這樣最大的好處就是,產生的時間間隔準確均勻。Server Timer和Thread Timer的區(qū)別在于,Server Timer是基于事件的,而Thread Timer是基于Callback的。
相比之下Thread Timer更輕量級一些,所以下文主要以Thread Timer為例,講解如何利用Thread Timer在ASP.NET中實現(xiàn)計劃任務。
下面給出一個用Timer實現(xiàn)計劃任務的類:
public class ScheduledTask
{
private static readonly ScheduledTask _ScheduledTask = null;
private Timer UpdateTimer = null;
//間隔時間,這里設置為15分鐘
private int Interval = 15 * 60000;
private int _IsRunning;
static ScheduledTask()
{
_ScheduledTask = new ScheduledTask();
}
public static ScheduledTask Instance()
{
return _ScheduledTask;
}
public void Start()
{
if(UpdateTimer == null)
{
UpdateTimer = new Timer(new TimerCallback(UpdateTimerCallback), null, Interval, Interval);
}
}
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
public void Stop()
{
if(UpdateTimer != null)
{
UpdateTimer.Dispose();
UpdateTimer = null;
}
}
}
首先,注意一下這段:private int _IsRunning;
_IsRunning是一個標志,它代表上一個時間間隔觸發(fā)的任務是否運行完成。
為什么我們需要這個_IsRunning標志呢?
因為,如果我們執(zhí)行的任務時間很長,就可能造成上一個時間段觸發(fā)的任務還沒有執(zhí)行完成,下一個任務又開始了,這樣就會造成重入的問題。為了解決這個問題,我們用_IsRunning作為一個標志,表示上次的任務是否完成了,如果完成了,我們就執(zhí)行新的任務,如果沒完成就跳過這次的任務繼續(xù)執(zhí)行上次的任務。
具體的邏輯在下面這段代碼中實現(xiàn):
程序代碼
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
大家看到,上面代碼中用到了Interlocked.Exchange這個方法。該方法的作用是保證多線程下給對象賦值的安全性。因為在多線程下,我們直接給_IsRunning賦值是不安全的,所以在這種情況下Interlocked.Exchange就派上了用場。
說完了ScheduledTask類的實現(xiàn),下面我們看看如何在ASP.NET中調用這個類。
建議在Application_Start中調用這個類,代碼如下:
程序代碼
public class Global : System.Web.HttpApplication
{
protected void Application_Start(object sender, EventArgs e)
{
ScheduledTask.Instance().Start();
}
protected void Application_End(object sender, EventArgs e)
{
ScheduledTask.Instance().Stop();
}
}
OK,以上就是Timer在ASP.NET中的簡單應用,如果有什么說的不對的地方,還請多多指教。
Server Timer(System.Timers.Timer),Thread Timer(System.Threading.Timer )和Windows Timer(System.Windows.Forms.Timer)。
其中Windows Timer和WinAPI中的Timer一樣,是基于消息的,而且是單線程的。另外兩個Timer則不同于Windows Timer,它們是基于ThreadPool的,這樣最大的好處就是,產生的時間間隔準確均勻。Server Timer和Thread Timer的區(qū)別在于,Server Timer是基于事件的,而Thread Timer是基于Callback的。
相比之下Thread Timer更輕量級一些,所以下文主要以Thread Timer為例,講解如何利用Thread Timer在ASP.NET中實現(xiàn)計劃任務。
下面給出一個用Timer實現(xiàn)計劃任務的類:
public class ScheduledTask
{
private static readonly ScheduledTask _ScheduledTask = null;
private Timer UpdateTimer = null;
//間隔時間,這里設置為15分鐘
private int Interval = 15 * 60000;
private int _IsRunning;
static ScheduledTask()
{
_ScheduledTask = new ScheduledTask();
}
public static ScheduledTask Instance()
{
return _ScheduledTask;
}
public void Start()
{
if(UpdateTimer == null)
{
UpdateTimer = new Timer(new TimerCallback(UpdateTimerCallback), null, Interval, Interval);
}
}
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
public void Stop()
{
if(UpdateTimer != null)
{
UpdateTimer.Dispose();
UpdateTimer = null;
}
}
}
首先,注意一下這段:private int _IsRunning;
_IsRunning是一個標志,它代表上一個時間間隔觸發(fā)的任務是否運行完成。
為什么我們需要這個_IsRunning標志呢?
因為,如果我們執(zhí)行的任務時間很長,就可能造成上一個時間段觸發(fā)的任務還沒有執(zhí)行完成,下一個任務又開始了,這樣就會造成重入的問題。為了解決這個問題,我們用_IsRunning作為一個標志,表示上次的任務是否完成了,如果完成了,我們就執(zhí)行新的任務,如果沒完成就跳過這次的任務繼續(xù)執(zhí)行上次的任務。
具體的邏輯在下面這段代碼中實現(xiàn):
程序代碼
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
大家看到,上面代碼中用到了Interlocked.Exchange這個方法。該方法的作用是保證多線程下給對象賦值的安全性。因為在多線程下,我們直接給_IsRunning賦值是不安全的,所以在這種情況下Interlocked.Exchange就派上了用場。
說完了ScheduledTask類的實現(xiàn),下面我們看看如何在ASP.NET中調用這個類。
建議在Application_Start中調用這個類,代碼如下:
程序代碼
public class Global : System.Web.HttpApplication
{
protected void Application_Start(object sender, EventArgs e)
{
ScheduledTask.Instance().Start();
}
protected void Application_End(object sender, EventArgs e)
{
ScheduledTask.Instance().Stop();
}
}
OK,以上就是Timer在ASP.NET中的簡單應用,如果有什么說的不對的地方,還請多多指教。
您可能感興趣的文章:
- Asp.Net(C#)自動執(zhí)行計劃任務的程序實例分析分享
- asp.net 在客戶端顯示服務器端任務處理進度條的探討
- asp.net 定時間點執(zhí)行任務的簡易解決辦法
- asp.net 每天定點執(zhí)行任務
- asp.net 計劃任務管理程序實現(xiàn),多線程任務加載
- C#(asp.net)多線程用法示例(可用于同時處理多個任務)
- ASP.NET 計劃任務實現(xiàn)方法(不使用外接程序,.net內部機制實現(xiàn))
- 詳解免費開源的DotNet任務調度組件Quartz.NET(.NET組件介紹之五)
- Asp.net ajax實現(xiàn)任務提示頁面的簡單代碼
- .NET Core基于Generic Host實現(xiàn)后臺任務方法教程
相關文章
asp.net 通過httpModule計算頁面的執(zhí)行時間
有時候我們想檢測一下網頁的執(zhí)行效率。記錄下開始請求時的時間和頁面執(zhí)行完畢后的時間點,這段時間差就是頁面的執(zhí)行時間了。要實現(xiàn)這個功能,通過HttpModule來實現(xiàn)是最方便而且準確的。2011-02-02linq to sql中,如何解決多條件查詢問題,答案,用表達式樹!
有個小項目中,用到了linq to sql,既然這樣,想必需要做多條件組合查詢了,雖然我對表達式樹的研究也只是寥寥地,但除此方法,似乎別無他法,只好硬著頭皮研究一下.2011-08-08.net core 基于Hangfire+Mysql持久化實現(xiàn)定時任務配置方法
這篇文章主要介紹了.net core 基于Hangfire+Mysql持久化實現(xiàn)定時任務配置方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-07-07XslTransform.Transform將結果輸出到字符串里的方法
XslTransform.Transform將結果輸出到字符串里的方法...2007-04-04