C#Windows服务 - 本地计算机上的服务是否已启动然后停止?

时间:2011-08-18 18:14:02

标签: c# process windows-services

我正在尝试创建我的第一个Windows服务,但很难过......在我从services.msc手动启动服务后,消息'本地计算机上的服务已启动然后停止。一些服务自动停止,他们没有工作要做'

我确信我的代码中肯定存在一些错误......

namespace ConvertService
{
public partial class Service1 : ServiceBase
{
    public Service1()
    {
        this.ServiceName = "ConvertService";
        this.EventLog.Log = "Application";
    }
    static void main()
    {

        ServiceBase.Run(new Service1());
    }


    protected override void OnStart(string[] args)
    {
        Process pMP3 = new Process();
        pMP3.StartInfo.UseShellExecute = false;
        pMP3.StartInfo.RedirectStandardOutput = true;
        pMP3.StartInfo.FileName = @"d:\...path...\converter.exe";
        pMP3.StartInfo.Arguments = @"d:\...path...\tempamr.amr " + @"d:\...path...\tempmp3.mp3 " + @"-cmp3";
        pMP3.Start();
        pMP3.WaitForExit();
        Process pWAV = new Process();
        pWAV.StartInfo.UseShellExecute = false;
        pWAV.StartInfo.RedirectStandardOutput = true;
        pWAV.StartInfo.FileName = @"d:\...path...\converter.exe";
        pWAV.StartInfo.Arguments = @"d:\...path...\tempmp3.mp3 " + @"d:\...path...\tempwav.wav " + @"-cwav";
        pWAV.Start();
        pWAV.WaitForExit();

    }

    protected override void OnStop()
    {
    }
}

}

如果我犯了愚蠢的错误,请原谅我。这是我的第一个Windows服务。

PS。我已经勾选了“允许服务与桌面交互”

3 个答案:

答案 0 :(得分:3)

您没有为OnStart方法创建正在运行的线程。基本上,服务管理器调用OnStart来启动服务,并且该调用需要在大约15秒左右完成。在内部,您应该创建一个带有循环的线程,该循环实际上会随着时间调用您的代码。像这样:

protected CancellationTokenSource _tokenSource = null;
protected Task _thread = null;

protected override void OnStart(string[] args)
{
    _tokenSource = new CancellationTokenSource();
    _thread = Task.Factory.StartNew(() => DoMyServiceLogic(), TaskCreationOptions.LongRunning, _tokenSource);
}

protected override void OnStop()
{
     _tokenSource.Cancel();
}

protected void DoMyServiceLogic()
{
     while(!_tokenSource.Token.IsCancellationRequested)
     {
         // Do Stuff
     }
}

您的服务并不真正遵循这种模式;你不是在不断做事,而应该更多的是一个控制台程序。

实际上,这是因为您的服务在完成OnStart方法后就会停止执行任何操作。这就像在控制台程序中完成Main时所发生的情况 - 应用程序刚刚退出。

答案 1 :(得分:0)

检查以确保您的服务运行的帐户可以访问这些文件(包括.wav和.mp3文件的写访问权限。)

您的代码也可能导致未处理的异常。我不确定,但这可能在事件日志中可见。您还可以使您的服务明确地将消息写入事件日志(如异常情况);看看这个链接:http://www.codeproject.com/KB/dotnet/simplewindowsservice.aspx

答案 2 :(得分:0)

打开eventvwr.msc。在那里,您将看到有关Windows服务停止工作的原因的异常详细信息。顺便说一句,你应该尽快离开OnStart方法,因为你只是 有30秒完成OnStart方法。 有一篇关于MSDN的优秀文章描述了“如何调试”Windows服务。