我正在尝试创建我的第一个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。我已经勾选了“允许服务与桌面交互”
答案 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服务。