2

我需要将 Apache Derby 服务器作为服务运行,以便 Derby 与安装它的机器一起启动。

现在,根据我的研究,我尝试了三种解决方案来创建这样的服务,但它们都不可行或产生错误。

  1. 使用 Java Service Wrapper:这是不可行的,因为他们只提供 30 天的免费试用。

  2. 使用 Windows 服务器管理器 (SrvMgr.exe) 创建如下所述的服务:http ://www.vogella.com/tutorials/ApacheDerby/article.html 。这似乎可行,因为我创建了一个显示在 Windows 注册表中的服务,可以通过“服务”面板启动/停止,并且某些东西正在使用http://localhost:1527Derby 服务器的默认地址。但是,如果我尝试通过 eclipse (luna) 或控制台连接到数据库,则会出现错误:

    Could not connect to DerbyPersistenceDeploy.
    Error creating SQL Model Connection connection to DerbyPersistenceDeploy. 
    (Error: DERBY SQL error: ERRORCODE: 40000, SQLSTATE: XJ041, SQLERRMC: 
    Failed to create database 'persistence', see the next exception for
    details.::SQLSTATE: XBM0J)
    DERBY SQL error: ERRORCODE: 40000, SQLSTATE: XJ041, SQLERRMC: 
    Failed to create database 'persistence', see the next exception for
    details.::SQLSTATE: XBM0J
    Error creating JDBC Connection connection to DerbyPersistenceDeploy. 
    (Error: DERBY SQL error: ERRORCODE: 40000, SQLSTATE: XJ041, SQLERRMC: 
    Failed to create database 'persistence', see the next exception for 
    details.::SQLSTATE: XBM0J)
    DERBY SQL error: ERRORCODE: 40000, SQLSTATE: XJ041, SQLERRMC: 
    Failed to create database 'persistence', see the next exception for             
    details.::SQLSTATE: XBM0J 
    

    这是该服务的注册表项的图像: 注册表项

  3. 我绑定的最后一种方法是使用 Apache procrun ( http://commons.apache.org/proper/commons-daemon/procrun.html )。我完成了本教程(http://joerglenhard.wordpress.com/2012/05/29/build-windows-service-from-java-application-with-procrun/)并设法让示例服务运行. 但是,当我尝试调整 tuorial 中发布的脚本时,出现以下错误(来自日志文件):

    [2014-07-21 16:52:20] [error] [ 3708] 
    Method 'static void start(String[])' not found in Class org/apache/derby/drda/NetworkServerControl
    [2014-07-21 16:52:20] [error] [ 6228] 
    Failed to start Java
    [2014-07-21 16:52:20] [error] [ 6228] 
    ServiceStart returned 4
    [2014-07-21 16:52:20] [error] [ 6228] 
    Commons Daemon procrun failed with exit value: 3 (Failed to run service as console application)
    

    这是我改编的用于创建 Web 服务的脚本:

    set SERVICE_NAME=DerbyPersistenceService
    set PR_INSTALL=D:\Program-Files\commons-daemon-1.0.15-bin-windows\prunsrv.exe
    
    REM Service log configuration
    set PR_LOGPREFIX=%SERVICE_NAME%
    set PR_LOGPATH=D:\04_server\derby\DerbyServiceScript\logs
    set PR_STDOUTPUT=D:\04_server\derby\DerbyServiceScript\logs\stdout.txt
    set PR_STDERROR=D:\04_server\derby\DerbyServiceScript\logs\stderr.txt
    set PR_LOGLEVEL=Error
    
    REM Path to java installation
    set PR_JVM=C:\Program Files (x86)\Java\jdk1.7.0_65\jre\bin\client\jvm.dll
    set PR_CLASSPATH=%DERBY_HOME%/lib/derby.jar;
                     %DERBY_HOME%/lib/derbynet.jar;
                     %DERBY_HOME%/lib/derbyclient.jar;
                     %DERBY_HOME%/lib/derbytools.jar
    
    REM Startup configuration
    set PR_STARTUP=auto
    set PR_STARTMODE=jvm
    set PR_STARTCLASS=org.apache.derby.drda.NetworkServerControl
    set PR_STARTPARAM=start
    set PR_STARTMETHOD=main
    
    REM Shutdown configuration
    set PR_STOPMODE=jvm
    set PR_STOPCLASS=org.apache.derby.drda.NetworkServerControl
    set PR_STOPPARAM=shutdown
    set PR_STOPMETHOD=main
    
    REM JVM configuration
    set PR_JVMMS=256
    set PR_JVMMX=1024
    set PR_JVMSS=4000
    set PR_JVMOPTIONS=-Duser.language=US;-Duser.region=en
    REM Install service 
    D:\Program-Files\commons-daemon-1.0.15-bin-windows\prunsrv.exe //IS//%SERVICE_NAME%
    

    我认为这个错误源于Startup- 和Shutdown-Configurations没有以正确的方式配置但我不知道它们应该是什么样子。

如果有人知道方法 2 或 3 的解决方案,我将不胜感激。

问候

[edit1:] 我按照 Bryan Pendleton 的建议编辑了我的 Procrun 脚本。

[edit2:]服务给了我一个新的错误信息: 错误信息 2

stderr.txt

    2014-07-23 16:41:14 Commons Daemon procrun stderr initialized

stdout.txt

    2014-07-23 16:41:14 Commons Daemon procrun stdout initialized
    Wed Jul 23 16:41:14 CEST 2014 : No command given.
    Usage: NetworkServerControl <commands> 
    Commands:
    start [-h <host>] [-p <port number>] [-noSecurityManager] [-ssl <ssl mode>]
    shutdown [-h <host>][-p <port number>] [-ssl <ssl mode>] [-user <username>] [-password <password>]
    ping [-h <host>][-p <port number>] [-ssl <ssl mode>]
    sysinfo [-h <host>][-p <port number>] [-ssl <ssl mode>]
    runtimeinfo [-h <host>][-p <port number>] [-ssl <ssl mode>]
    logconnections { on|off } [-h <host>][-p <port number>] [-ssl <ssl mode>]
    maxthreads <max>[-h <host>][-p <port number>] [-ssl <ssl mode>]
    timeslice <milliseconds>[-h <host>][-p <port number>] [-ssl <ssl mode>]
    trace { on|off } [-s <session id>][-h <host>][-p <port number>] [-ssl <ssl mode>]
    tracedirectory <trace directory>[-h <host>][-p <port number>] [-ssl <ssl mode>]

DerbyPersistenceService.2014-07-23.log是空的。

我认为方法参数有问题。

[edit3:]更改了脚本,因此它是一个可行的解决方案。非常感谢 Bryan Pendleton 帮助我完成这个。

    set SERVICE_NAME=DerbyPersistenceService
    set PR_INSTALL=D:\Program-Files\commons-daemon-1.0.15-bin-windows\prunsrv.exe

    REM Service log configuration
    set PR_LOGPREFIX=%SERVICE_NAME%
    set PR_LOGPATH=D:\04_server\derby\DerbyServiceScript\logs
    set PR_STDOUTPUT=D:\04_server\derby\DerbyServiceScript\logs\stdout.txt
    set PR_STDERROR=D:\04_server\derby\DerbyServiceScript\logs\stderr.txt
    set PR_LOGLEVEL=Error

    REM Path to java installation
    set PR_JVM=C:\Program Files (x86)\Java\jdk1.7.0_65\jre\bin\client\jvm.dll
    set PR_CLASSPATH=%DERBY_HOME%/lib/derby.jar;
                     %DERBY_HOME%/lib/derbynet.jar;
                     %DERBY_HOME%/lib/derbyclient.jar;
                     %DERBY_HOME%/lib/derbytools.jar

    REM Startup configuration
    set PR_STARTUP=auto
    set PR_STARTMODE=jvm
    set PR_STARTCLASS=org.apache.derby.drda.NetworkServerControl
    set PR_STARTPARAMS=start
    set PR_STARTMETHOD=main

    REM Shutdown configuration
    set PR_STOPMODE=jvm
    set PR_STOPCLASS=org.apache.derby.drda.NetworkServerControl
    set PR_STOPPARAMS=shutdown
    set PR_STOPMETHOD=main

    REM JVM configuration
    set PR_JVMMS=256
    set PR_JVMMX=1024
    set PR_JVMSS=4000
    set PR_JVMOPTIONS=-Duser.language=US;-Duser.region=en
    REM Install service 
    D:\Program-Files\commons-daemon-1.0.15-bin-windows\prunsrv.exe //IS//%SERVICE_NAME%  
4

2 回答 2

2

我相信 PR_STARTMETHOD 和 PR_STOPMETHOD 应该是'main',因为你想调用 NetworkServerControl 的 main() 方法。

我相信 'start' 和 'shutdown' 是您需要传递给 main() 方法的参数。

所以他们应该分别进入 STARTPARAMS 和 STOPPARAMS。

于 2014-07-22T21:38:49.927 回答
0

我遇到了同样的问题,并尝试使用各种工具和包装器将 Derby 作为 Windows 服务,其中包括 Derby wiki ( http://wiki.apache.org/db-derby/DerbyWindowsService )中描述的所有方式.

无论如何,除了 Appache 基金会提供的 procrun 工具外,这些工具都没有对我有用,它在 tomcat 中用于将此服务器作为 Windows 服务器。因此,请按照以下步骤操作:

  1. 获取 procrun 的两个关键文件(http://commons.apache.org/proper/commons-daemon/binaries.html):
    • prunsrv.exe - 用于将应用程序作为服务运行的服务应用程序。
    • prunmgr.exe - 用于监视和配置已安装服务的 GUI 管理器应用程序。
  2. 将这些文件复制到 Derby/bin(假设您有一个名为 Derby 的文件夹,即 DERBY_HOME)。
  3. 要遵循 procrun 约定,请将这些文件重命名为 derby.exe 和 derbyw.exe。如果您想使用不同的名称,您可以,但您应该调整附加的脚本。
  4. 要在 Windows 上创建服务,您必须执行下一个脚本。它被编写为在 Derby 文件夹的上级文件夹 (..) 上执行,并使用 java 32 位的可移植版本。

    • 注意:我已将其拆分为不同的行,但必须仅在一行中执行

    Derby\bin\derby.exe //IS//DerbyService --DisplayName
    ="Derby Service" --Description
    ="这是一个 Derby 数据库服务器"
    --Install="%cd%\Derby\bin\derby.exe" --Startup=auto
    --JavaHome " %cd%\Java_32_portable "
    --Jvm=" %cd%\Java_32_portable\bin\client\jvm.dll "
    --StartMode=Java --StopMode=Java
    --StartClass=org. apache.derby.drda.NetworkServerControl --StartParams=start
    --StopClass=org.apache.derby.drda.NetworkServerControl --StopParams=shutdown
    --Classpath="%cd%\Derby\lib\derby.jar;%cd% \Derby\lib\derbyrun.jar;%cd%\Derby\lib\derbynet.jar;%cd%\Derby\lib\derbytools.jar"
    ++JvmOptions="-Dderby.system.home=%cd%\Derby;-Dderby.install.url=%cd%\Derby\lib;-Dderby.authentication.provider=BUILTIN;-Dderby.storage.pageCacheSize=8000;-Dderby.storage .pageSize=20000;-Dderby.database.sqlAuthorization=false "

  5. 重要的。您应该调整粗体部分。

    • 适当地设置你的 JAVA_HOME 变量和你的 jvm.dll
    • 在 ++JvmOptions 中设置您自己的 Derby 特定参数,用“;”分隔。例如,添加用户密码验证:
      -Dderby.database.sqlAuthorization=true;-Dderby.user."user-name"=password
  6. 最后,您可以检查您的服务是否正常启动

    net start DerbyService

建议:您可以像我一样将所有内容放在一个 bat 文件中,您可以在其中定义先前的 JAVA_HOME 或任何其他必要的变量。

于 2014-09-05T09:25:38.570 回答