【问题标题】:Apache daemons procrun prunsrv Windows exe mode not workingApache daemons procrun prunsrv Windows exe 模式不工作
【发布时间】:2012-09-22 14:30:22
【问题描述】:

几年来,我们一直在使用 Procrun 将 Java 应用程序转变为服务(并且没有问题)。
我们还有一些作为服务运行的原生 Windows 可执行文件。到目前为止,我们使用 Windows Management Instrumentation (WMI) 来定义这些,但我现在正尝试将 Procrun 用于这些本机 exe ......不幸的是,我无法启动服务(或至少保持运行)。
服务似乎正确创建; Prunsrvlog/stdout/stderr 不包含错误; Apache/procrun 和 system/Services 下的注册表项似乎都可以创建;我可以使用 Windows 服务小程序或 Prunmgr 监视器查看服务;但是...服务从未显示为已启动。当我尝试从 Prunmgr 手动启动服务时,我收到“...正在尝试启动”弹出窗口几秒钟,但服务仍然停止。
当我尝试从 Win Services 小程序启动它时,我还得到一个弹出窗口:服务启动和停止。如果不使用,某些服务会自动停止”。

我自己找到了大部分解决方案:
我不知何故弄乱了我的本机测试程序,它总是与 Windows 服务控制器交互...使用 Procrun 时,您的本机程序不得(取消)向 Windows 服务控制器注册自己 ,因为这是由 Procrun 自己处理的。更正我的测试服务后,我可以使用 Procrun 服务启动和停止它。

... 但仍有几个问题:

  1. 我发现一些命中告诉serviceName 不能包含空格,但我也(痛苦地)发现displayName 在使用 Procrun 用于本机可执行文件时不能包含空格。如果displayName 包含空格,Windows 服务小程序中的属性页 将拒绝打开。我不知道这可能是什么原因,这在使用 Java 应用程序时不适用。

  2. 即使您将服务设置为自动启动(例如通过set PR_STARTUP=auto),当您install 时,“本机”服务也不会启动,它需要一个明确的启动命令(例如bin\TestService start)(但是“本机”服务将在每次重新启动时自动启动)...这同样不适用于包装 Java 应用程序...这些在安装时自动启动。

最后一点建议:当使用set PR_xxx=format 定义服务的参数时,通常不能引用包含空格的值...这对于一些更有经验的人来说是不言而喻的,但是我为此受了不少苦 :-(

这篇长文的其余部分主要是历史(或罕见的感兴趣的个人)

定义服务的代码:

set MY_HOME=c:\program files (x86)\testProgs\
cd /d "%MY_HOME%"
set PR_INSTALL=c:\program files (x86)\testProgs\bin\TestService
set PR_DISPLAYNAME=TestProg_Shared_Memory_Service
set PR_DESCRIPTION=Shared Memory Server for Testing Purposes
set PR_STARTUP=auto
set PR_LOGPATH=c:\program files (x86)\testProgs\logs
set PR_STDOUTPUT=auto
set PR_STDERROR=auto
set PR_STARTMODE=exe
set PR_STARTPATH=c:\program files (x86)\testProgs
set PR_STARTIMAGE=c:\program files (x86)\testProgs\bin\TPShmSrvD.exe
set PR_STARTPARAMS=PORT=9088;PATH=c:\program files (x86)\testProgs
set PR_STOPMODE=exe
set PR_STOPIMAGE=%MY_HOME%bin\TPCommand.exe
set PR_STOPPARAMS=PORT=9088;STOP;SHMSRV
set PR_LOGLEVEL=DEBUG
bin\TestService install

正如我后来发现的,不要忘记添加:

bin\TestService start

commons-daemon.log 中的结果:

[2012-09-22 15:26:32] [debug] ( prunsrv.c:1644) Commons Daemon procrun log initialized
[2012-09-22 15:26:32] [info]  ( prunsrv.c:1648) Commons Daemon procrun (1.0.10.0 32-bit) started
[2012-09-22 15:26:32] [debug] ( prunsrv.c:559 ) Installing service...
[2012-09-22 15:26:32] [info]  ( prunsrv.c:595 ) Service TestService name TestProg_Shared_Memory_Service
[2012-09-22 15:26:32] [debug] ( prunsrv.c:611 ) Setting service description Shared Memory Server for Testing Purposes
[2012-09-22 15:26:32] [info]  ( prunsrv.c:629 ) Service 'TestService' installed
[2012-09-22 15:26:32] [info]  ( prunsrv.c:1729) Commons Daemon procrun finished
[2012-09-22 15:27:00] [debug] ( prunsrv.c:1644) Commons Daemon procrun log initialized
[2012-09-22 15:27:00] [info]  ( prunsrv.c:1648) Commons Daemon procrun (1.0.10.0 32-bit) started
[2012-09-22 15:27:00] [info]  ( prunsrv.c:1561) Running 'TestService' Service...
[2012-09-22 15:27:00] [debug] ( prunsrv.c:1345) Inside ServiceMain...
[2012-09-22 15:27:00] [info]  ( prunsrv.c:1089) Starting service...
[2012-09-22 15:27:00] [info]  ( prunsrv.c:1244) Service started in 15 ms.
[2012-09-22 15:27:00] [debug] ( prunsrv.c:1496) Waiting for worker to finish...
[2012-09-22 15:27:01] [debug] ( prunsrv.c:1501) Worker finished.
[2012-09-22 15:27:01] [debug] ( prunsrv.c:1524) Waiting for all threads to exit
[2012-09-22 15:27:01] [debug] ( prunsrv.c:1528) JVM destroyed.
[2012-09-22 15:27:01] [info]  ( prunsrv.c:1563) Run service finished.
[2012-09-22 15:27:01] [info]  ( prunsrv.c:1729) Commons Daemon procrun finished

TestService stdout/stderr 都只包含一行“stdout/stderr initialised”
ProcRun 下的注册表项:

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\TestService]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\TestService\Parameters]

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\TestService\Parameters\Log]
"Path"="c:\\program files (x86)\\testProgs\\logs"
"Level"="DEBUG"
"StdError"="auto"
"StdOutput"="auto"

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\TestService\Parameters\Start]
"Image"="c:\\program files (x86)\\testProgs\\bin\\TPShmSrvD.exe"
"WorkingPath"="c:\\program files (x86)\\testProgs"
"Params"=hex(7):50,00,4f,00,52,00,54,00,3d,00,39,00,30,00,38,00,38,00,00,00,50,\
  00,41,00,54,00,48,00,3d,00,63,00,3a,00,5c,00,70,00,72,00,6f,00,67,00,72,00,\
  61,00,6d,00,20,00,66,00,69,00,6c,00,65,00,73,00,20,00,28,00,78,00,38,00,36,\
  00,29,00,5c,00,74,00,65,00,73,00,74,00,50,00,72,00,6f,00,67,00,73,00,00,00,\
  00,00
"Mode"="exe"

[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\TestService\Parameters\Stop]
"Image"="c:\\program files (x86)\\testProgs\\bin\\TPCommand.exe"
"Params"=hex(7):50,00,4f,00,52,00,54,00,3d,00,39,00,30,00,38,00,38,00,00,00,53,\
  00,54,00,4f,00,50,00,00,00,53,00,48,00,4d,00,53,00,52,00,56,00,00,00,00,00
"Mode"="exe"

在 SYSTEM\Services 下:

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TestService]
"Type"=dword:00000010
"Start"=dword:00000002
"ErrorControl"=dword:00000001
"ImagePath"=hex(2):22,00,63,00,3a,00,5c,00,70,00,72,00,6f,00,67,00,72,00,61,00,\
  6d,00,20,00,66,00,69,00,6c,00,65,00,73,00,20,00,28,00,78,00,38,00,36,00,29,\
  00,5c,00,74,00,65,00,73,00,74,00,50,00,72,00,6f,00,67,00,73,00,5c,00,62,00,\
  69,00,6e,00,5c,00,54,00,65,00,73,00,74,00,53,00,65,00,72,00,76,00,69,00,63,\
  00,65,00,22,00,20,00,2f,00,2f,00,52,00,53,00,2f,00,2f,00,54,00,65,00,73,00,\
  74,00,53,00,65,00,72,00,76,00,69,00,63,00,65,00,00,00
"DisplayName"="TestProg_Shared_Memory_Service"
"DependOnService"=hex(7):54,00,63,00,70,00,69,00,70,00,00,00,41,00,66,00,64,00,\
  00,00,00,00
"WOW64"=dword:00000001
"ObjectName"="LocalSystem"
"Description"="Shared Memory Server for Testing Purposes"

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TestService\Parameters]

我已经尝试了几乎所有我能想到的,但我无法让服务运行:-(
还有两点:
1. 我原来在 DisplayName 中有空格。在将它们替换为下划线之前,我无法在 Windows 服务小程序中打开 属性页面!!!

2. 本机 exe 具有向 Windows 服务控制器 注册的代码(主要用于在 Windows 关闭时启用干净终止)。如果可执行文件的名称以“d.exe”结尾(不区分大小写),则会执行此代码。我尝试对 StartImage 使用这两种形式(即 TPShmSrvD.exe 和 TPShmSrv.exe),但无济于事...

任何帮助将不胜感激,

朱尔

【问题讨论】:

    标签: java windows service native procrun


    【解决方案1】:

    这可能不是最终答案,但在命令下方运行

    c:\Temp>prunsrv.exe //IS//VIJAY
    

    创建名为 VIJAY 的服务

    c:\temp\prunmgr.exe //ES//VIJAY
    

    启动 UI 以编辑服务 VIJAY

    从 UI 编辑参数很容易

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-02-04
      • 1970-01-01
      • 2012-09-10
      • 1970-01-01
      相关资源
      最近更新 更多