今天用c#寫windows服務程式,寫啊寫啊,查了資料,網上有篇文章寫得不錯
在很多應用中需要做windows服務來操作資料庫等操作,比如
(1)一些非常慢的資料庫操作,不想一次性去做,想慢慢的通過服務定時去做,比如定時為Database Backup等
(2)在.net Remoting中利用windows服務來做Host
利用vs.net我們可以在幾分鐘之內建立其windows服務,非常簡單
下面說一下步驟
1. 建立一個項目
2. 從一個可用的項目模板列表當中選擇Windows服務
3. 設計器會以設計模式開啟
4. 從工具箱的組件表當中拖動一個Timer對象到這個設計表面上 (注意: 要確保是從組件列表而不是從Windows表單列表當中使用Timer)
5. 設定Timer屬性,Interval屬性200毫秒(1秒進行5次資料庫操作)
6. 然後為這個服務填加功能
7.雙擊這個Timer,然後在裡面寫一些資料庫操作的代碼,比如
SqlConnection conn=new SqlConnection("server=127.0.0.1;database=test;uid=sa;pwd=275280");
SqlCommand comm=-new SqlCommand("insert into tb1 ('111',11)",conn);
conn.Open();
comm.ExecuteNonQuery();
conn.Close();
8. 將這個服務程式切換到設計檢視
9. 右擊設計檢視選擇“添加安裝程式”
from:http://post.blog.hexun.com/imagine18/trackback.aspx?articleid=6056177
10. 切換到剛被添加的ProjectInstaller的設計檢視
11. 設定serviceInstaller1組件的屬性:
1) ServiceName = My Sample Service
2) StartType = Automatic (開機自動運行)
12. 設定serviceProcessInstaller1組件的屬性 Account = LocalSystem
13. 改變路徑到你項目所在的bin\Debug檔案夾位置(如果你以Release模式編譯則在bin\Release檔案夾)
14. 執行命令“InstallUtil MyWindowsService.exe”註冊這個服務,使它建立一個合適的註冊項。(InstallUtil這個程式在WINDOWS檔案夾\Microsoft.NET\Framework\v1.1.4322下面)
15. 右擊案頭上“我的電腦”,選擇“管理”就可以打電腦管理主控台
16. 在“服務和應用程式”裡面的“服務”部分裡,你可以發現你的Windows服務已經包含在服務列表當中了
17. 右擊你的服務選擇啟動就可以啟動你的服務了
看看資料庫是不是一秒多了5個記錄啊
(InstallUtil/u MyWindowsService.exe刪除服務)