まず、Windowsサービスを作成します
1)Windowsサービスプロジェクトを作成します。
2)サービスの名前の変更
サービスService1の名前の変更は、あなたの名前はここではServiceTestを命名しました。
第二に、サービスのインストーラを作成します
1)インストーラを追加します。
その後、我々は地図で見ると、自動的にProjectInstaller.cs私たちのために2つの取り付けコンポーネントを作成することができます。
2)インストールサービス名を変更
右serviceInsraller1は、ServiceNameにの値がServiceTestを変更し、[プロパティ]を選択します。
インストールする3)変更権限
右serviceProcessInsraller1は、[プロパティ]を選択し、アカウントの値は、ローカルシステムを変更しました。
第三に、書き込みサービスコード
1)を開き、コードServiceTest
右ServiceTestは、コードの表示を選択します。
2)サービスのロジックを書きます
システムを使用しました。
System.Collections.Genericを使用しました。
System.ComponentModelを使用しました。
System.Dataを使用しました。
たSystem.Diagnosticsを使用しました。
System.Linqのを使用しました。
System.ServiceProcessを使用しました。
System.Textのを使用しました。
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
|
string
CurrentDirectory = System.Environment.CurrentDirectory;
System.Environment.CurrentDirectory = CurrentDirectory +
"\\Service"
;
Process process =
new
Process();
process.StartInfo.UseShellExecute =
false
;
process.StartInfo.FileName =
"Install.bat"
;
process.StartInfo.CreateNoWindow =
true
;
process.Start();
System.Environment.CurrentDirectory = CurrentDirectory;
|
2)卸载
卸载时也会产生目录问题,所以卸载代码如下:
1
2
3
4
5
6
7
8
|
string
CurrentDirectory = System.Environment.CurrentDirectory;
System.Environment.CurrentDirectory = CurrentDirectory +
"\\Service"
;
Process process =
new
Process();
process.StartInfo.UseShellExecute =
false
;
process.StartInfo.FileName =
"Uninstall.bat"
;
process.StartInfo.CreateNoWindow =
true
;
process.Start();
System.Environment.CurrentDirectory = CurrentDirectory;
|
3)启动
代码如下:
1
2
3
4
5
|
using
System.ServiceProcess;
ServiceController serviceController =
new
ServiceController(
"ServiceTest"
);
serviceController.Start();
|
4)停止
1
2
3
|
ServiceController serviceController =
new
ServiceController(
"ServiceTest"
);
if
(serviceController.CanStop)
serviceController.Stop();
|
5)暂停/继续
1
2
3
4
5
6
7
8
|
ServiceController serviceController =
new
ServiceController(
"ServiceTest"
);
if
(serviceController.CanPauseAndContinue)
{
if
(serviceController.Status == ServiceControllerStatus.Running)
serviceController.Pause();
else
if
(serviceController.Status == ServiceControllerStatus.Paused)
serviceController.Continue();
}
|
6)检查状态
1
2
|
ServiceController serviceController =
new
ServiceController(
"ServiceTest"
);
string
Status = serviceController.Status.ToString();
|
六、调试Windows Service
1)安装并运行服务
2)附加进程
3)在代码中加入断点进行调试
七、总结
本文对Windows service的创建和安装 ,可运行的Windows Service,从而达到了工作的需求。