如何用.NET創(chuàng)建Windows服務(wù)
發(fā)表時間:2024-02-11 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]我們將研究如何創(chuàng)建一個作為Windows服務(wù)的應(yīng)用程序。內(nèi)容包含什么是Windows服務(wù),如何創(chuàng)建、安裝和調(diào)試它們。會用到System.ServiceProcess.ServiceBase命名空間的類。 什么是Windows服務(wù)? Windows服務(wù)應(yīng)用程序是一種需要長期運(yùn)行的應(yīng)用程序,它對于服...
我們將研究如何創(chuàng)建一個作為Windows服務(wù)的應(yīng)用程序。內(nèi)容包含什么是Windows服務(wù),如何創(chuàng)建、安裝和調(diào)試它們。會用到System.ServiceProcess.ServiceBase命名空間的類。
什么是Windows服務(wù)?
Windows服務(wù)應(yīng)用程序是一種需要長期運(yùn)行的應(yīng)用程序,它對于服務(wù)器環(huán)境特別適合。它沒有用戶界面,并且也不會產(chǎn)生任何可視輸出。任何用戶消息都會被寫進(jìn)Windows事件日志。計算機(jī)啟動時,服務(wù)會自動開始運(yùn)行。它們不要用戶一定登錄才運(yùn)行,它們能在包括這個系統(tǒng)內(nèi)的任何用戶環(huán)境下運(yùn)行。通過服務(wù)控制管理器,Windows服務(wù)是可控的,可以終止、暫停及當(dāng)需要時啟動。
Windows 服務(wù),以前的NT服務(wù),都是被作為Windows NT操作系統(tǒng)的一部分引進(jìn)來的。它們在Windows 9x及Windows Me下沒有。你需要使用NT級別的操作系統(tǒng)來運(yùn)行Windows服務(wù),諸如:Windows NT、Windows 2000 Professional或Windows 2000 Server。舉例而言,以Windows服務(wù)形式的產(chǎn)品有:Microsoft Exchange、SQL Server,還有別的如設(shè)置計算機(jī)時鐘的Windows Time服務(wù)。
創(chuàng)建一個Windows服務(wù)
我們即將創(chuàng)建的這個服務(wù)除了演示什么也不做。服務(wù)被啟動時會把一個條目信息登記到一個數(shù)據(jù)庫當(dāng)中來指明這個服務(wù)已經(jīng)啟動了。在服務(wù)運(yùn)行期間,它會在指定的時間間隔內(nèi)定期創(chuàng)建一個數(shù)據(jù)庫項目記錄。服務(wù)停止時會創(chuàng)建最后一條數(shù)據(jù)庫記錄。這個服務(wù)會自動向Windows應(yīng)用程序日志當(dāng)中登記下它成功啟動或停止時的記錄。
Visual Studio .NET能夠使創(chuàng)建一個Windows服務(wù)變成相當(dāng)簡單的一件事情。啟動我們的演示服務(wù)程序的說明概述如下。
1. 新建一個項目
2. 從一個可用的項目模板列表當(dāng)中選擇Windows服務(wù)
3. 設(shè)計器會以設(shè)計模式打開
4. 從工具箱的組件表當(dāng)中拖動一個Timer對象到這個設(shè)計表面上 (注意: 要確保是從組件列表而不是從Windows窗體列表當(dāng)中使用Timer)
5. 設(shè)置Timer屬性,Enabled屬性為False,Interval屬性30000毫秒
6. 切換到代碼視圖頁(按F7或在視圖菜單當(dāng)中選擇代碼),然后為這個服務(wù)填加功能
Windows服務(wù)的構(gòu)成
在你類后面所包含的代碼里,你會注意到你所創(chuàng)建的Windows服務(wù)擴(kuò)充了System.ServiceProcess.Service類。所有以.NET方式建立的Windows服務(wù)必須擴(kuò)充這個類。它會要求你的服務(wù)重載下面的方法,Visual Studio默認(rèn)時包括了這些方法。
• Dispose – 清除任何受控和不受控資源(managed and unmanaged resources)
• OnStart – 控制服務(wù)啟動
• OnStop – 控制服務(wù)停止
數(shù)據(jù)庫表腳本樣例
在這個例子中使用的數(shù)據(jù)庫表是使用下面的T-SQL腳本創(chuàng)建的。我選擇SQL Server數(shù)據(jù)庫。你可以很容易修改這個例子讓它在Access或任何你所選擇的別的數(shù)據(jù)庫下運(yùn)行。
CREATE TABLE [dbo].[MyServiceLog] (
[in_LogId] [int] IDENTITY (1, 1) NOT NULL,
[vc_Status] [nvarchar] (40)
COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,
[dt_Created] [datetime] NOT NULL
) ON [PRIMARY]
[1] [2] [3] [4] 下一頁