13

这个问题似乎被广泛讨论,但在我的特定案例中找到解决方案时我遇到了问题。

我的服务设置为在Local System帐户下运行。在我的第一台安装了Windows 7 SP1(64 位)的机器上,一切正常。但是,就在我尝试使用Windows Server 2008 R2 SP1 (64-bit)在我的第二台机器上启动服务之后,甚至没有第二次通过,我正面临这个恼人的错误:

Windows could not start the ProService service on Local Computer
Error 1053: The service did not respond to the start or control request in a timely fashion

显示System Log2个条目:

The ProService service failed to start due to the following error: 
The service did not respond to the start or control request in a timely fashion.

和:

A timeout was reached (30000 milliseconds) while waiting for the ProService service to connect.

实现如下所示:

程序.cs:

static void Main()
{
    AppDomain.CurrentDomain.UnhandledException += CurrentDomainUnhandledException;
    ServiceBase.Run(new ServiceBase[] { new ProService() });
}

static void CurrentDomainUnhandledException(object sender, UnhandledExceptionEventArgs e)
{
    if (e != null && e.ExceptionObject != null)
    {
        Logger.Record(e.ExceptionObject);
    }            
}

ProService.cs:

public ProService()
{
    InitializeComponent();
}

protected override void OnStart(string[] args)
{
    try
    {
        RequestAdditionalTime(10000);
        FireStarter.Instance.Execute();
    }
    catch (Exception e)
    {
        Logger.Record(e);
        throw;
    }            
}

OnStart方法只是启动一个新线程,因此执行几乎不需要任何时间。我使用RequestAdditionalTime声明以防万一-拒绝将此事作为我的问题的根源。此外,如您所见,我正在处理所有异常,但在启动期间没有异常写入我的自定义服务事件日志(顺便说一句:日志记录正在第一台 win7 机器上工作)。如何调查发生了什么?

4

5 回答 5

10

我已经通过几个步骤弄清楚了发生了什么:

  1. 我已经编写了控制台应用程序 - 包装器基本上是在OnStart服务方法中完成的。
  2. 我已经执行了控制台应用程序 - 应用程序正常启动。
  3. 我已将服务配置文件的内容复制到控制台应用程序配置文件。
  4. 我再次执行了控制台应用程序 - 应用程序立即静默中止(出乎意料地类似于我们的服务行为,出了点问题)。
  5. 我比较了 2 个配置 - 来自服务和来自控制台应用程序的原始配置。结果,我发现了一些差异。其中,有这样一个条目 - 问题的根源(删除后,一切正常):

    <startup>
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
    

所以基本上我有过时的配置文件。以前服务是在.NET 4.5下编译的,然后我将框架更改为4.0并将文件部署到服务器,但保留了以前的配置文件(我更改了目标框架,因为我的开发机器有.NET 4.5而服务器有不是)。我不会认为显示的行会在没有任何合理信息的情况下隐藏所有问题,这有助于跟踪混乱。

于 2013-01-04T09:08:44.040 回答
2

检查缺少的依赖项/DLL。

如果您还没有这样做,请允许您的服务作为常规应用程序调用(长期调试的一种很好的技术),并查看它是否在您的 Windows 2008 机器上正常启动。

如果以这种方式工作,那么在 LocalSystem 帐户中运行可能会出现问题。继续从在 LocalSystem 帐户中运行的命令提示符启动您的应用程序(此处的示例设置)。

于 2013-01-02T14:53:44.737 回答
1

我尝试了此链接提供的以下修复

  1. 单击开始,单击运行,键入 regedit,然后单击确定。

  2. 找到并单击以下注册表子项:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control

  3. 在右窗格中,找到 ServicesPipeTimeout 条目。
    注意 如果 ServicesPipeTimeout 条目不存在,您必须创建它。为此,请按照下列步骤操作
    :在编辑菜单上,指向新建,然后单击 DWORD 值。
    湾。键入 ServicesPipeTimeout,然后按 Enter。
  4. 右键单击 ServicesPipeTimeout,然后单击修改。
  5. 单击十进制,键入 60000,然后单击确定。
    此值表示服务超时之前的时间(以毫秒为单位)。
  6. 重新启动计算机。

但我仍然有启动服务的问题。

对我有用的修复是,

  1. 转到 services.msc
  2. 双击您要启动的服务。
  3. 采取登录选项卡
  4. 将登录身份更改为:本地系统帐户。
  5. 尝试在此更改后启动服务。(仍然给出 1053 错误)
  6. 再次选择登录选项卡,将其更改为网络服务(随机提供新密码)
  7. 尝试再次启动服务。(服务完美启动)
于 2013-10-31T15:08:41.047 回答
0

我尝试了以下步骤。它就像一个魅力。

1.转到 services.msc 2.双击您要启动的服务。3.Take 登录选项卡 4.Changed 登录为:本地系统帐户。5.更改后尝试启动服务。(仍然给出1053错误) 6.再次登录选项卡,将其更改为网络服务(随机输入新密码) 7.再次尝试启动服务。(服务已启动完美)

但我只想知道会是什么问题。

于 2015-07-15T08:14:24.300 回答
0

安装服务后,我必须授予安装文件夹的完全控制权限(每个人)。然后,我的服务将完美启动。

于 2015-08-03T13:20:46.343 回答