几年来,我们一直在使用Procrun将Java应用程序转换为服务(并且没有问题)
我们还有一些作为服务运行的本机Windows可执行文件。到目前为止,我们使用Windows Management Instrumentation(WMI)来定义这些,但我现在正尝试将Procrun用于这些本机exe ...不幸的是,我无法启动服务(或者至少保留运行)。
该服务似乎正确创建; Prunsrvlog / stdout / stderr不包含错误; Apache / procrun和system / Services下的注册表项似乎都可以创建;我可以使用Windows服务小程序或Prunmgr监视器查看该服务;但是......服务从未显示为已启动。当我尝试从Prunmgr手动启动服务时,我得到“...尝试启动”弹出窗口几秒钟,但服务仍然停止。
当我尝试从Win Services applet启动时,我还会弹出一个:服务启动和停止。如果不使用,有些服务会自动停止“。
我自己找到了大部分解决方案:
我以某种方式弄乱了我的原生测试程序,它总是与Windows服务控制器交互... 使用Procrun时,您的本机程序不得(de)使用Windows服务控制器注册自己 ,因为这是由Procrun自己处理的。在纠正我的测试服务后,我可以使用Procrun服务启动和停止它。
...... 但仍有几个问题:
serviceName
不能包含空格,但我(痛苦地)发现当使用Procrun作为本机可执行文件时displayName
不能包含空格。如果displayName
包含空格,则Windows服务小程序中的属性页将拒绝打开。我不知道这可能是什么原因,这在使用Java应用程序时不适用。set PR_STARTUP=auto
),当您install
时,也不会启动“本机”服务,并且它需要一个明确的启动命令(例如{{1 (>)“本机”服务将在每次重启时自动启动... ...这在包装Java应用程序时再次不适用...这些在安装时自动启动。最后一点建议:当使用bin\TestService start
格式定义服务的参数时,通常不得引用包含空格的值...对于一些经验丰富的人来说,这可能不言而喻,但我从中受了很多苦恼:-(
这篇长篇文章的剩余部分主要是历史(或罕见的感兴趣的个人)
定义服务的代码:
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
commons-daemon.log中的结果:
bin\TestService start
TestService stdout / stderr只包含一行说“stdout / stderr initialised”
ProcRun下的注册表项:
[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
在SYSTEM \ Services下:
[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"
我已经尝试了我能想到的一切,但我无法让服务运行:-(
还有两个评论:
1.我最初在 DisplayName 中有空格。在我用下划线替换它们之前,我无法打开Windows服务小程序中的属性页 !!!
2.本机exe有代码注册 Windows服务控制器(主要是为了在Windows关闭时启用干净终止)。如果可执行文件的名称以“ d.exe ”结尾(不区分大小写),则会执行此代码。我尝试将这两种形式(即TPShmSrvD.exe和TPShmSrv.exe)用于 StartImage ,但无济于事...
任何帮助将不胜感激,
Juul的
答案 0 :(得分:0)
这可能不是最终答案,但可以在命令下运行
c:\Temp>prunsrv.exe //IS//VIJAY
创建名称为VIJAY的服务
c:\temp\prunmgr.exe //ES//VIJAY
启动UI以编辑服务VIJAY
从UI
轻松编辑参数