Windows服務樣例
下面是一個測試案例,服務名爲Service1 黑色部分爲自動生成,紅色部分爲我加進去的代碼,綠色爲我加入的註釋,此案例沒有其他意義,只是將記錄插入到數據庫中。
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.ServiceProcess;
using System.Configuration.Install;
using SysData.Db;
namespace serverTest
{
public class Service1 : System.ServiceProcess.ServiceBase
{
private System.Timers.Timer timer1;
/// <summary>
/// 必需的設計器變量。
/// </summary>
private System.ComponentModel.Container components = null;
public Service1()
{
// 該調用是 Windows.Forms 組件設計器所必需的。
InitializeComponent();
// TODO: 在 InitComponent 調用後添加任何初始化
}
// 進程的主入口點
static void Main()
{
System.ServiceProcess.ServiceBase[] ServicesToRun;
// 同一進程中可以運行多個用戶服務。若要將
//另一個服務添加到此進程,請更改下行
// 以創建另一個服務對象。例如,
//
// ServicesToRun = New System.ServiceProcess.ServiceBase[] {new Service1(), new MySecondUserService()};
//
ServicesToRun = new System.ServiceProcess.ServiceBase[] { new Service1() };
System.ServiceProcess.ServiceBase.Run(ServicesToRun);
}
/// <summary>
/// 設計器支持所需的方法 - 不要使用代碼編輯器
/// 修改此方法的內容。
/// </summary>
private void InitializeComponent()
{
this.timer1 = new System.Timers.Timer();
((System.ComponentModel.ISupportInitialize)(this.timer1)).BeginInit();
//
// timer1
//
this.timer1.Enabled = true;
this.timer1.Interval = 30000;
this.timer1.Elapsed += new System.Timers.ElapsedEventHandler(this.timer1_Elapsed);
//
// Service1
//
this.ServiceName = "Service1";
((System.ComponentModel.ISupportInitialize)(this.timer1)).EndInit();
}
/// <summary>
/// 清理所有正在使用的資源。
/// </summary>
protected override void Dispose( bool disposing )
{
if( disposing )
{
if (components != null)
{
components.Dispose();
}
}
base.Dispose( disposing );
}
/// <summary>
/// 設置具體的操作,以便服務可以執行它的工作。
/// </summary>
protected override void OnStart(string[] args)
{
// TODO: 在此處添加代碼以啓動服務。
this.timer1.Enabled = true;
this.LogMessage("Service Started");
}
/// <summary>
/// 停止此服務。
/// </summary>
protected override void OnStop()
{
// TODO: 在此處添加代碼以執行停止服務所需的關閉操作。 this.timer1.Enabled = false;
this.LogMessage("Service Stopped"); }
private void LogMessage(string xMsg)
{
try
{
//這裏向數據庫中插入一條信息爲 xMsg的記錄,下邊是我調用事先寫好的Db類添加記錄的方法,您也可以使用其他辦法來寫入數據庫。
//Db.QuerySQL("Insert into SysMsg (SysMsg) values ('"+xMsg+"')"); }
catch
{
//不做任何操作 }
}
private void timer1_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
{
LogMessage("檢查服務運行!"); }
}
}
|