我创建了一个 .NET Windows 服务并从 bin/debug 文件夹安装了调试版本(是的,我知道这不是一个好方法,但我只想能够测试它并附加调试器)。
该服务基本上在无限循环中运行,检查 FTP 目录中的文件、处理它们、休眠一分钟然后循环。
当我尝试启动服务时,出现以下错误
Error 1053: The service did not respond to the start or control request in a timely fashion
进一步检查该服务正在完成第一个循环,然后在第一个线程睡眠期间超时。因此,我对如何启动服务感到有些困惑。是我(缺乏)对线程的理解导致了这种情况吗?
我的起始代码是
protected override void OnStart(string[] args)
{
eventLog.WriteEntry("Service started");
ThreadStart ts = new ThreadStart(ProcessFiles);
workerThread = new Thread(ts);
workerThread.Start();
}
在 ProcessFiles 函数中,一旦完成一个循环,我只需
eventLog.WriteEntry("ProcessFiles Loop complete");
Thread.Sleep(new TimeSpan(0,1,0));
当我检查事件日志时,'ProcessFiles Loop complete' 日志在那里,但这是服务超时之前的最后一个事件并且无法启动。
有人可以解释我做错了什么吗?
编辑
我在 ProcessFiles 函数中处理循环的方式如下
while (!this.serviceStopped)
{
// Do Stuff
eventLog.WriteEntry("ProcessFiles Loop complete");
Thread.Sleep(new TimeSpan(0,1,0));
}
干杯
斯图尔特