本文介紹了如何用C#建立、安裝、啟動、監控、解除安裝簡單的Windows Service 的内容步驟和注意事項。
一、建立一個Windows Service
1)建立Windows Service項目

2)對Service重命名
将Service1重命名為你服務名稱,這裡我們命名為ServiceTest。
二、建立服務安裝程式
1)添加安裝程式
之後我們可以看到上圖,自動為我們建立了ProjectInstaller.cs以及2個安裝的元件。
2)修改安裝服務名
右鍵serviceInsraller1,選擇屬性,将ServiceName的值改為ServiceTest。
3)修改安裝權限
右鍵serviceProcessInsraller1,選擇屬性,将Account的值改為LocalSystem。
三、寫入服務代碼
1)打開ServiceTest代碼
右鍵ServiceTest,選擇檢視代碼。
2)寫入Service邏輯
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Linq;
using System.ServiceProcess;
using System.Text;
using System.Data.SqlClient;
namespace DataBaseService
{
public partial class DataBakService : ServiceBase
{
public DataBakService()
{
InitializeComponent();
}
//定時器
System.Timers.Timer tmBak = new System.Timers.Timer();
//伺服器啟動時寫日志、開啟定時器
protected override void OnStart(string[] args)
{
using (System.IO.StreamWriter sw = new System.IO.StreamWriter("D:\\log.txt", true))
{
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " DATABASENAME Service Start.");
}
//到時間的時候執行事件
tmBak.Interval = 60000;//一分鐘執行一次
tmBak.AutoReset = true;//執行一次 false,一直執行true
//是否執行System.Timers.Timer.Elapsed事件
tmBak.Enabled = true;
tmBak.Start();
tmBak.Elapsed += new System.Timers.ElapsedEventHandler(SQLBak);
}
private void SQLBak(object source, System.Timers.ElapsedEventArgs e)
{
//如果目前時間是10點30分
if (DateTime.Now.Hour == 9 && DateTime.Now.Minute == 50)
{
string sql = string.Format(@"
BACKUP DATABASE DATABASENAME
TO DISK = N'E:\DBBak\DATABASENAME {0}{1}{2}.bak'--目錄一定要存在
WITH INIT , NOUNLOAD ,
NAME = N'資料庫備份', --名字随便取
NOSKIP ,
STATS = 10,
NOFORMAT", DateTime.Now.Year,DateTime.Now.Month,DateTime.Now.Day);
try
{
using (System.IO.StreamWriter sw = new System.IO.StreamWriter("D:\\log.txt", true))
{
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " 正在備份DATABASENAME 資料庫......");
}
SqlConnection conn = new SqlConnection("server=127.0.0.1;uid=sa;pwd=44545454;database=DATABASENAME ");
conn.Open();
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.CommandTimeout = 0;
cmd.ExecuteNonQuery();
conn.Close();
}
catch (Exception ex)
{
using (System.IO.StreamWriter sw = new System.IO.StreamWriter("D:\\log.txt", true))
{
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " 備份DATABASENAME 資料庫出現異常:" + ex.Message);
return;
}
}
using (System.IO.StreamWriter sw = new System.IO.StreamWriter("D:\\log.txt", true))
{
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " 備份DATABASENAME 資料庫成功!");
}
}
}
//服務停止時寫日志
protected override void OnStop()
{
using (System.IO.StreamWriter sw = new System.IO.StreamWriter("D:\\log.txt", true))
{
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " DATABASENAME
Service Stop.");
}
}
}
}
這是一個備份資料庫的服務,邏輯很簡單,就是通過定時器實作在特定的時間執行SQL語句備份資料庫,并将每一步操作的情況寫入日志檔案。
四、建立安裝腳本
在項目中添加2個檔案如下(必須是ANSI或者UTF-8無BOM格式):
1)安裝腳本Install.bat
%SystemRoot%\Microsoft.NET\Framework\v4.0.30319\installutil.exe D:\dbback\EFNETSYSDBBAK\DataBaseService.exe
Net Start ServiceEFNETSYS
sc config ServiceEFNETSYS start= auto
pause
2)解除安裝腳本Uninstall.bat
%SystemRoot%\Microsoft.NET\Framework\v4.0.30319\installutil.exe /u D:\dbback\EFNETSYSDBBAK\DataBaseService.exe
pause
3)安裝腳本說明
第二行為啟動服務。
第三行為設定服務為自動運作。
這2行視服務形式自行選擇。
4)腳本調試
如果需要檢視腳本運作狀況,在腳本最後一行加入pause
五、在C#中對服務進行控制
0)配置目錄結構
履歷一個新WPF項目,叫WindowsServiceTestUI,添加對System.ServiceProcess的引用。
在WindowsServiceTestUI的bin\Debug目錄下建立Service目錄。
将WindowsServiceTest的生成目錄設定為上面建立的Service目錄。
生成後目錄結構如下圖
1)安裝
安裝時會産生目錄問題,是以安裝代碼如下:
1 2 3 4 5 6 7 8 | |
2)解除安裝
解除安裝時也會産生目錄問題,是以解除安裝代碼如下:
1 2 3 4 5 6 7 8 | |
3)啟動
代碼如下:
1 2 3 4 5 | |
4)停止
1 2 3 | |
5)暫停/繼續
1 2 3 4 5 6 7 8 | |
6)檢查狀态
1 2 | |
六、調試Windows Service
1)安裝并運作服務
2)附加程序
3)在代碼中加入斷點進行調試
七、總結
本文對Windows service的上述配置都未做詳細解釋,但是按上述步驟就可以制作可運作的Windows Service,進而達到了工作的需求。
轉載于:https://www.cnblogs.com/charlie-chen2016/p/8031774.html