部署grails应用程序时stacktrace.log出现问题

| 我在部署grails应用程序时遇到问题。 我得到以下异常:
log4j:ERROR setFile(null,true) call failed.
java.io.FileNotFoundException: stacktrace.log (Permission denied)
    at java.io.FileOutputStream.openAppend(Native Method)
    at java.io.FileOutputStream.<init>(FileOutputStream.java:177)
    at java.io.FileOutputStream.<init>(FileOutputStream.java:102)
    at org.apache.log4j.FileAppender.setFile(FileAppender.java:294)
    at org.apache.log4j.FileAppender.activateOptions(FileAppender.java:165)
    at org.apache.log4j.spi.OptionHandler$activateOptions.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:40)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:116)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:120)
    at org.codehaus.groovy.grails.plugins.logging.Log4jConfig.createFullstackTraceAppender(Log4jConfig.groovy:177)
    at org.codehaus.groovy.grails.plugins.logging.Log4jConfig.this$2$createFullstackTraceAppender(Log4jConfig.groovy)
    at org.codehaus.groovy.grails.plugins.logging.Log4jConfig$this$2$createFullstackTraceAppender.callCurrent(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(CallSiteArray.java:44)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:141)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:145)
    at org.codehaus.groovy.grails.plugins.logging.Log4jConfig.configure(Log4jConfig.groovy:145)
    at org.codehaus.groovy.grails.web.util.Log4jConfigListener.contextInitialized(Log4jConfigListener.java:62)
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4135)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4630)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)
    at org.apache.catalina.core.StandardService.start(StandardService.java:519)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:581)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
May 25, 2011 11:16:54 PM org.apache.catalina.core.ApplicationContext log
INFO: Initializing Spring root WebApplicationContext
我在配置程序中对记录器的设置如下所示:
log4j = { 
    appenders {
        rollingFile name: \"stacktrace\", maxFileSize: 1024, file: \"/var/www/logs/myapp-stacktrace.log\"
     }
 }
我也试图用禁用记录器     log4j = {         附录{             \'null \'名称:\“ stacktrace \”          }      } 该目录的权限是为tomcat用户设置的
-rwxr--r-- 1 tomcat6 root 0 May 24 18:38 myapp-stacktrace.log
根本没有成功...感谢您的反馈和帮助!     
已邀请:
我遇到了与Grails 1.3.7类似的问题,并发现此问题已解决(通过将堆栈跟踪日志推送到标准日志目录中)
log4j = {
    appenders {
    rollingFile name: \"stacktrace\", maxFileSize: 1024, file: \"/var/logs/piws-stacktrace.log\"
    ....
    
在http://www.grails.org/Deployment/#Tomcat上查看有关将Grails应用程序部署到Tomcat的官方文档。 引用相关部分... \“请注意,在默认设置下,Grails会尝试将某些文件(通常是stacktrace.log和h2数据库)写入tomcat目录。您的Tomcat目录可能安装了root所有者/组,而Tomcat服务器以用户tomcat6。这将导致您的应用程序无法启动,并出现写许可权错误。要么更改您的Grails生产设置,以使这些文件以正确的权限写到其他位置,要么更改Tomcat目录的所有者(对于Unix:/ var / lib / tomcat6)到tomcat6(或您使用TOMCAT6_USER设置设置的任何tomcat用户)。\“ 您可以使用ѭ4来更改所有者(如果需要,请替换运行tomcat的用户和写入日志的目录),这是在大多数情况下最简单,最合适的解决方案。     
检查磁盘空间(远景)并尝试更改为777,以验证其权限问题。如果是,则您要么没有以tomcat用户身份运行tomcat,要么您的目录已关闭...     

要回复问题请先登录注册