Java Apache守护程序ProRun prunsrv Windows exe模式不工作

Java Apache守护程序ProRun prunsrv Windows exe模式不工作,java,windows,service,native,procrun,Java,Windows,Service,Native,Procrun,几年来,我们一直在使用ProCurn将Java应用程序转化为服务(而且没有问题)。 我们还有一些本机Windows可执行文件作为服务运行。到目前为止,我们使用Windows Management Instrumentation(WMI)来定义这些,但我现在也尝试将ProCurn用于这些本机exe。。。不幸的是,我无法启动服务(或至少无法保持运行)。 服务似乎创建正确;Prunsrvlog/stdout/stderr不包含错误;Apache/procrun和system/Services下的注册表

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

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

……但仍有几个问题:

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

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

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

    这篇长篇博文的其余部分主要是关于历史(或少数感兴趣的个人)

    用于定义服务的代码:

    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已初始化”
    ProLUN下的注册表项:

    [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"
    
    在系统\服务下:

    [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 Services小程序中打开属性页!!!

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

    任何帮助都将不胜感激,


    Juul

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

    c:\Temp>prunsrv.exe //IS//VIJAY
    
    创建名为VIJAY的服务

    c:\temp\prunmgr.exe //ES//VIJAY
    
    启动UI以编辑服务

    从UI编辑参数很容易