Windows服务没有完全启动

时间:2011-06-08 00:16:29

标签: c# windows-services threadpool queueuserworkitem

我在c#中创建了这个小窗口服务,我相信我的ThreadPool代码可能做错了,导致Windows服务无法完全启动。如果你必须知道,Windows服务似乎只是在查看服务控制台时完美运行,它仍然表明它正在“启动”。当我重新启动服务器时,即使我已将其设置为自动启动,该服务似乎已再次停止。

请参阅下面的代码:

protected override void OnStart(string[] args)
{
     int itemCount = itemList.Count;

     this.doneEvents = new ManualResetEvent[itemCount];
     for (int i = 0; i < itemCount; i++)
     {
         int oId = this.itemList[i];
         this.doneEvents[i] = new ManualResetEvent(false);

         ThreadPool.QueueUserWorkItem(data =>
         {
             while (this.activated)
             {
                 DateTime start = DateTime.Now;

                 // my code here

                 // choke point
                 TimeSpan duration = (DateTime.Now - start);
                 if (duration.Milliseconds < CONST_WAITMILLISECONDS)
                    Thread.Sleep((CONST_WAITMILLISECONDS - duration.Milliseconds));
              }

              this.doneEvents[i].Set(); // thread done

            }, oId);
         }

         WaitHandle.WaitAll(doneEvents);

}

2 个答案:

答案 0 :(得分:3)

您阻止OnStart WaitHandle.WaitAll(doneEvents);来电。 Windows尝试启动服务但由于WaitAll而超时。

如果您希望Windows将服务视为已启动,则需要让OnStart完成。

答案 1 :(得分:2)

我认为你可以将OnStart内的逻辑包装在一个线程中。收到OnStop事件时,此主题将被关闭。

这样的事情:

Thread _ServiceThread;
protected override void OnStart(string[] args) { 
    _ServiceThread = new Thread(() => { /* your current OnStart logic here...*/ });
    _ServiceThread.Start();
}
protected override void OnStop() {
    _ServiceThread.Stop();
}