C#Windows服務程序開發實例淺析
C#Windows服務程序開發實例:編寫一個C#Windows服務程序,定時從數據庫中拿出記錄發送郵件。
測試環境:Visual Studio 2005 SP1、Windows Server 2003 SP2
C#Windows服務程序開發實例一、新建項目
打開VS2005,新建一個“Windows 服務”項目。
C#Windows服務程序開發實例二、添加Timer
展開“工具箱”,在“組件”標簽下找到“Timer”雙擊,這時就添加了一個Timer組件,修改“Name”屬性為“timEmail”、“Enabled”為“false”、“Interval”為“60000”。
接下來要做一些修補工作,不知是VS2005的BUG還是我沒找著地方,在VS2003下是不存在該問題的:剛從“組件”下添加的“Timer”按理說應該來自“System.Timers命名空間”,也只有“System.Timers.Timer”才能在Windows服務程序中正常工作,但是現在這個Timer卻是屬于“System.Windows.Forms.Timer”的。所以得稍作修改,打開“.Designer.cs”文件,修改如下:
- #region 組件設計器生成的代碼
- //........以上略
- /// <summary>
- /// 設計器支持所需的方法 - 不要
- /// 使用代碼編輯器修改此方法的內容。
- /// </summary>
- private void InitializeComponent()
- {
- this.components = new System.ComponentModel.Container();
- //this.timEmail = new System.Windows.Forms.Timer(this.components);原
- this.timEmail = new System.Timers.Timer();//改
- this.timEmail.Interval = 60000;
- this.ServiceName = "Service1";
- }
- #endregion
- //private System.Windows.Forms.Timer timEmail;原
- private System.Timers.Timer timEmail;//改
C#Windows服務程序開發實例三、添加配置文件
服務每次調用配置文件,獲取一些基本參數,這樣一些變更就可直接修改配置文件而不必修改代碼。新建ServiceConfig.xml存放于項目“Bin\Debug\”下:
- ﹤?xml version="1.0" encoding="utf-8" ?﹥
- ﹤serviceConfig﹥
- ﹤serviceItem
- name="sendEmail"
- enable="true"
- elapsed="60000"
- connectionString="your database connection..."
- smtp="smtp address"
- account="your email account..."
- password="your password..." ﹥
- ﹤/serviceItem﹥
- ﹤/serviceConfig﹥
C#Windows服務程序開發實例四、以下是實現代碼
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Diagnostics;
- using System.ServiceProcess;
- using System.Text;
- using System.Xml;//操作配置文件
- using System.IO;//寫日志
- using System.Threading;//使用線程
- namespace ClientWindowsService
- {
- public partial class ClientService : ServiceBase
- {
- public ClientService()
- {
- InitializeComponent();
- }
- protected override void OnStart(string[] args)
- {
- //服務啟動
- this.timEmail.Enabled = true;
- this.tSendEmail();
- }
- protected override void OnStop()
- {
- //服務停止
- this.timEmail.Enabled = false;
- }
- private void timEmail_Elapsed(object sender,
- System.Timers.ElapsedEventArgs e)
- {
- //定時器
- this.tSendEmail();
- }
- //開啟新進程發送郵件
- private void tSendEmail()
- {
- Thread t = new Thread(new ThreadStart(sendEmail));
- t.Start();
- }
- //發送郵件函數
- private void sendEmail()
- {
- XmlDocument doc = new XmlDocument();
- //添加System.Windows.Forms引用,獲取執行目錄
- string configFile = System.Windows.Forms.Application.
- StartupPath.ToString() + "\ServiceConfig.xml";
- doc.Load(@configFile);
- XmlElement root = doc.DocumentElement;
- foreach (XmlNode node in root)
- {
- //如果配置文件中開啟服務
- if (node.Attributes["name"].Value == "sendEmail" &&
- node.Attributes["enable"].Value == "true")
- {
- try
- {
- //讀取數據庫,發送郵件操作,略
- }
- catch (Exception error)
- {
- //寫錯誤日志
- using (StreamWriter sw = new
- StreamWriter(System.Windows.Forms.
- Application.StartupPath.ToString() +
- @"" + DateTime.Now.ToString("yyyy-MM-dd") +
- ".txt", true, System.Text.Encoding.UTF8))
- {
- sw.WriteLine(DateTime.Now.ToString() + ":");
- sw.WriteLine(error.ToString());
- sw.WriteLine("----------------
- -----------------------------");
- sw.Close();
- }
- }
- }
- }//end foreach
- }
- }//end class
- }//end namespace
C#Windows服務程序開發實例五、布署服務
在設計模式下右鍵-->添加安裝程序-->設置serviceProcessInstaller1的Account為LocalSystem
設置serviceInstaller1的StartType為Automatic
編譯
在命令模式下執行:%systemroot%\microsoft.net\framework\v2.0.50727\installUtil.exe D:\項目目錄\bin\Debug\可執行文件名.exe
在每次需要修改Windows服務時,這就會要求你卸載和重新安裝這個服務。不過要注意在卸載這個服務前,最好確保服務管理控制臺已經關閉,這會是一個很好的習慣。如果沒有這樣操作的話,你可能在卸載和重安裝Windows服務時會遇到麻煩。僅卸載服務的話,可以執行相的InstallUtil命令用于注銷服務,不過要在后面加一個/u命令開關。
調試Windows服務
從另外的角度度看,調試Windows服務絕不同于一個普通的應用程序。調試Windows服務要求的步驟更多。服務不能象你對普通應用程序做的那樣,只要簡單地在開發環境下執行就可以調試了。服務必須首先被安裝和啟動,這一點在前面部分我們已經做到了。為了便于跟蹤調試代碼,一旦服務被啟動,你就要用Visual Studio把運行的進程附加進來(attach)。記住,對你的Windows服務做的任何修改都要對這個服務進行卸載和重安裝。
附加正在運行的Windows服務
為了調試程序,有些附加Windows服務的操作說明。這些操作假定你已經安裝了這個Windows服務并且它正在運行。
1. 用Visual Studio裝載這個項目
2. 點擊“調試”菜單
3. 點擊“進程”菜單
4. 確保 顯示系統進程 被選
5. 在 可用進程 列表中,把進程定位于你的可執行文件名稱上點擊選中它
6. 點擊 附加 按鈕
7. 點擊 確定
8. 點擊 關閉
9. 在timer1_Elapsed方法里設置一個斷點,然后等它執行
C#Windows服務程序開發實例六、代碼下載
http://files.cnblogs.com/linckle/log.rar
C#Windows服務程序開發實例的基本內容就向你介紹到這里,希望對你學習和了解C#Windows服務程序開發實例有所幫助。
【編輯推薦】