2

我需要我的服务在启动过程中检查某些文件的存在和结构,如果不满足某些条件则退出/失败/停止。我读了这个帖子:Windows 服务失败的正确方法是什么? 但这无济于事。

我将 ServiceBase.ExitCode 属性设置为非零,然后调用 ServiceBase.Stop。但我得到 5 个事件日志条目。见下文:

Starting service. (I log this event via code)
Config.xml file not found. (I log this ERROR event via code)
Service stopped successfully. (SCM logs this message)
Service started successfully. (SCM logs this message)
Service cannot be started. The handle is invalid  (SCM logs this message)

如您所见,除了最后两个条目外,一切正常。他们为什么在那里?如何在启动期间正确关闭服务?为什么 SCM 看不到服务已停止/失败?

4

3 回答 3

1

您没有提供足够的代码来真正了解,但我怀疑您正在尝试验证服务并在构造函数或 OnStart 中停止它。我喜欢处理服​​务的方式是在 OnStart 中启动我的计时器。在计时器的第一个间隔中,我可以验证所有代码,如果它无效关闭服务。如果它有效,请将计时器的间隔重置为我希望它运行的频率,然后设置一个布尔值,告诉它不要再次检查文件的有效性。

于 2013-04-11T14:01:28.960 回答
0

您正在尝试启动第二个服务实例(为同一 .exe 注册的另一个服务)

于 2013-10-31T13:17:26.540 回答
0

您使用的返回码是ExitCode什么?如果它与相应的 windows 匹配ExitCode,那么这就是 SCM 将记录的内容。我假设你为你的 ExitCode.

另一件事是,如果您可以在默认值上运行,请让 Config.xml 丢失,并将问题记录在 EventLog 中。“配置文件丢失”

如果您真的希望它在 期间中止OnStart,请设置ExitCode然后抛出异常(InvalidArgumentExceptionInvalidOperationException)例如

这篇文章也有一些很好的建议。.NET:缺少所需的配置设置时会抛出哪个异常?

于 2013-04-11T14:04:46.417 回答