2012-07-22 136 views
1

我尝试使用Java服务包装器(JSW)来运行Derby数据库作为Windows服务。我下载社区版3.5.15Java安全问题

有包装的配置我用:

wrapper.java.command=java 
#wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperSimpleApp 
wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperStartStopApp 

wrapper.java.classpath.1=../lib/derby.jar 
wrapper.java.classpath.2=../lib/derbynet.jar 
wrapper.java.classpath.3=../lib/derbytools.jar 
wrapper.java.classpath.4=Wrapper.jar 

wrapper.java.library.path.1= 

wrapper.java.additional.1=-Dderby.system.home=c:/data/derby 

#wrapper.app.parameter.1=org.apache.derby.drda.NetworkServerControl 
#wrapper.app.parameter.2=start 

wrapper.app.parameter.1=org.apache.derby.drda.NetworkServerControl 
wrapper.app.parameter.2=3 
wrapper.app.parameter.3=start 
wrapper.app.parameter.4=-h 
wrapper.app.parameter.5=127.0.0.1 
wrapper.app.parameter.6=org.apache.derby.drda.NetworkServerControl 
wrapper.app.parameter.7=true 
wrapper.app.parameter.8=1 
wrapper.app.parameter.9=shutdown 
wrapper.console.format=PM 
wrapper.console.loglevel=INFO 
wrapper.logfile=log/wrapper.log 
wrapper.logfile.format=LPTM 
wrapper.logfile.loglevel=INFO 
wrapper.logfile.maxsize=5m 
wrapper.logfile.maxfiles=10 
wrapper.syslog.loglevel=ERROR 

wrapper.console.title=Derby DB Server 
wrapper.ntservice.name=derby 
wrapper.ntservice.displayname=Apache Derby Database 
wrapper.ntservice.description=Apache Derby Relational Database Engine (Network Server) 
wrapper.ntservice.starttype=AUTO_START 
wrapper.ntservice.interactive=false 
#wrapper.ntservice.account=.\derby 
#wrapper.ntservice.password=derbypw 

,当我试图通过包装来启动Derby服务器我得到安全违反异常:

c:\derby\bin>wrapper -c derby.conf 
wrapper | --> Wrapper Started as Console 
wrapper | Java Service Wrapper Community Edition 32-bit 3.5.15 
wrapper | Copyright (C) 1999-2012 Tanuki Software, Ltd. All Rights Reserved. 
wrapper |  http://wrapper.tanukisoftware.com 
wrapper | 
wrapper | Launching a JVM... 
jvm 1 | WrapperManager: Initializing... 
jvm 1 | Sun Jul 22 22:11:11 BST 2012 : Security manager installed using the Basic server security policy. 
jvm 1 | Sun Jul 22 22:11:11 BST 2012 : Apache Derby Network Server - 10.9.1.0 - (1344872) started and ready to accept connections on port 1527 
jvm 1 | WrapperManager Error: Error in WrapperListener.start callback. java.security.AccessControlException: access denied (org.tanukisoftware.wrapper.security.WrapperPerm 
ission signalStarting) 
jvm 1 | WrapperManager Error: java.security.AccessControlException: access denied (org.tanukisoftware.wrapper.security.WrapperPermission signalStarting) 
jvm 1 | WrapperManager Error:  at java.security.AccessControlContext.checkPermission(Unknown Source) 
jvm 1 | WrapperManager Error:  at java.security.AccessController.checkPermission(Unknown Source) 
jvm 1 | WrapperManager Error:  at java.lang.SecurityManager.checkPermission(Unknown Source) 
jvm 1 | WrapperManager Error:  at org.tanukisoftware.wrapper.WrapperManager.signalStarting(WrapperManager.java:3268) 
jvm 1 | WrapperManager Error:  at org.tanukisoftware.wrapper.WrapperStartStopApp.start(WrapperStartStopApp.java:437) 
jvm 1 | WrapperManager Error:  at org.tanukisoftware.wrapper.WrapperManager$11.run(WrapperManager.java:3963) 
jvm 1 | WrapperManager Error: Unable to remove the Wrappers shudownhook: {0} 
jvm 1 | Exception in thread "WrapperListener_start_runner" java.security.AccessControlException: access denied (org.tanukisoftware.wrapper.security.WrapperPermission signal 
Stopped) 
jvm 1 |  at java.security.AccessControlContext.checkPermission(Unknown Source) 
jvm 1 |  at java.security.AccessController.checkPermission(Unknown Source) 
jvm 1 |  at java.lang.SecurityManager.checkPermission(Unknown Source) 
jvm 1 |  at org.tanukisoftware.wrapper.WrapperManager.signalStopped(WrapperManager.java:3320) 
jvm 1 |  at org.tanukisoftware.wrapper.WrapperManager.shutdownJVM(WrapperManager.java:4058) 
jvm 1 |  at org.tanukisoftware.wrapper.WrapperManager.privilegedStopInner(WrapperManager.java:4363) 
jvm 1 |  at org.tanukisoftware.wrapper.WrapperManager.access$2900(WrapperManager.java:124) 
jvm 1 |  at org.tanukisoftware.wrapper.WrapperManager$11.run(WrapperManager.java:3983) 
wrapper | CTRL-C trapped. Shutting down. 
wrapper | Shutdown failed: Timed out waiting for signal from JVM. 
wrapper | JVM did not exit on request, terminated 
wrapper | <-- Wrapper Stopped 

我可以权限授予增加的java.policy解决这个问题(我没有尝试过,但假设这会起作用)。

我想知道的事情是:什么强制执行的安全限制(并引发安全异常),在这种情况下?我认为所有本地启动的Java应用程序都被授予所有权限。

还有一件事,让我困惑:我有H2数据库服务器(1.3.162(2011-11-26))通过JSW(但早期版本)运行有没有它的安全性补助。我搜索了包含wrapper字的* .policy文件,并且没有任何内容。在这种情况下如何配置安全性,以及是否配置了安全性?病人:

,如果有人让这些安全问题更清楚,我将不胜感激。

+1

当你的日志输出显示,系统的某些部分(大概德比,看你的日志)安装了安全管理器 - 这是强制执行限制。安全管理器不会使用.policy文件 - 它可以通过编程或硬编码进行配置。 – DNA 2012-07-22 21:31:19

+0

@DNA,看来我明白了。德比安装了一些安全管理器,该策略对包装器运行的限制更多。这也解释了为什么h2无需额外配置即可完美运行。 – 2012-07-22 21:52:36

+1

当您使用Wrapper运行时,Wrapper类将启动您的应用程序的主要方法。这是将wrapper.jar中的类插入到调用堆栈中。 Java的安全模型通过限制对调用堆栈中授权给最弱方法的权限的访问来实现。 为了使这项工作,你需要给类的wrapper.jar权限做你想做的。这是在我们的网站描述如下: http://wrapper.tanukisoftware.com/doc/english/security-model.html – 2012-07-24 11:32:12

回答

1

把作为答案雷夫的评论:

当你与包装上运行,包装类启动应用程序的主要方法。这是将wrapper.jar中的类插入到调用堆栈中。 Java的安全模型通过限制对调用堆栈中授权给最弱方法的权限的访问来实现。为了使这项工作,你需要给wrapper.jar权限的类来做你想做的事。

这对我们的网站在这里描述:

http://wrapper.tanukisoftware.com/doc/english/security-model.html