3

我正在使用 apache commons daemon toolProcrun将 java 命令行工具安装为 Windows 服务。

java工具在运行过程中会在控制台显示很多内容。守护程序工具将自动将任何 sysout 记录到日志文件中。只要服务正在运行,就无法删除此文件。

问题:我的服务和我的应用程序几乎不应该重新启动。这会导致StdOutput每月数百 GB 的守护程序日志文件,我只能通过先停止应用程序手动清除。

问题:是否可以禁用此服务日志记录?

4

3 回答 3

8

--StdOutput您可以通过从配置脚本中省略and--StdError参数的文件名来避免将 stdout 和 stderr 写入文件。我有这个使用 v1.0.15.0

例如:

D:\prunsrv.exe //IS//SomeService ^
--DisplayName="SomeService" ^
--Description="Some Procrun Service" ^
--Startup=auto ^
--Install=%CD%\prunsrv.exe ^
--Jvm=%JAVA_HOME%\jre\bin\server\jvm.dll ^
--Classpath=%CD%\MyApplication-SNAPSHOT.jar; ^
--StartMode=jvm ^
--StartClass=com.myDomain.bootstrap ^
--StartMethod=start ^
--StartParams=start ^
--StopMode=jvm ^
--StopClass=com.myDomain.bootstrap ^
--StopMethod=stop ^
--StopParams=stop ^
--StdOutput= ^
--StdError= ^
--LogPath=%CD%\logs ^
--LogLevel=Debug ^
于 2015-09-08T18:18:05.040 回答
1

对我来说最佳实践是一个批处理文件,它对我来说非常简单:

安装服务.bat

REM Main
set SERVICE_NAME=MyService
set PR_DESCRIPTION=My Description
set PR_INSTALL=C:\procrun-sample-master\prunsrv.exe
set PR_STARTUP=auto

REM Java
set PR_JVM=%JAVA_HOME%\bin\server\jvm.dll
set PR_CLASSPATH=myservice.jar

REM LOG disabled
set PR_LOGPATH=C:\procrun-sample-master\log
set PR_STDOUTPUT=
set PR_STDERROR=
set PR_LOGLEVEL=Warn

REM Start Config
set PR_STARTUP=auto
set PR_STARTMODE=jvm
set PR_STARTCLASS=package.Classname
set PR_STARTMETHOD=start

REM Stop Config
set PR_STOPMODE=jvm
set PR_STOPCLASS=package.Classname
set PR_STOPMETHOD=stop

REM Install
prunsrv.exe //IS//%SERVICE_NAME%
于 2016-12-13T09:49:12.200 回答
0

通过以下步骤解决了此问题。

  1. 通过服务停止您的 apache服务

  2. 以管理员身份打开命令提示符 (cmd)

  3. 导航到您的 tomcat exe 文件位置,即

    cd D:\MyApplication\Apache-Tomcat\bin\

  4. 运行以下命令

    tomcat7.exe //US//JasperGenDoc --StdOutput=

  5. 通过Services启动你的 apache服务

于 2017-11-09T01:00:26.720 回答