2014-05-15 27 views
3

我遇到了部署Grails应用程序的问题。一切工作在本地测试环境中。部署Grails应用程序时出错 - 初学者

ERROR

[本地主机 - startStop-1] ERROR context.GrailsContextLoader - 错误 初始化应用程序:错误创建具有名称 'transactionManagerPostProcessor' 豆芽:初始化失败; 嵌套的异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为'transactionManager'的bean:在设置bean属性'sessionFactory'时无法将参考 解析为bean'sessionFactory'; 嵌套的例外是 org.springframework.beans.factory.BeanCreationException:错误 创建名称为bean的SessionFactory的“:无法解析参考 豆“hibernateProperties”而设置的bean属性 “hibernateProperties”;嵌套的异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为'hibernateProperties'的bean:无法解析 引用bean'dialectDetector',同时使用键[hibernate.dialect]设置bean属性 'properties';嵌套的异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为'dialectDetector'的bean:调用init方法 失败;嵌套的异常是 org.springframework.jdbc.support.MetaDataAccessException:错误,而 提取DatabaseMetaData;嵌套的例外是 org.apache.commons.dbcp.SQLNestedException:无法创建 PoolableConnectionFactory(IO例外: “java.io.FileNotFoundException:/var/lib/tomcat7/prodDb.lock.db (拒绝)”;“ /var/lib/tomcat7/prodDb.lock.db“[90031-164]) org.springframework.beans.factory.BeanCreationException:错误 使用名称'transactionManagerPostProcessor'创建bean: Bean初始化失败;嵌套的异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为'transactionManager'的bean:在设置bean属性'sessionFactory'时无法将引用 解析为bean'sessionFactory'; 嵌套的例外是 org.springframework.beans.factory.BeanCreationException:错误 创建名称为bean的SessionFactory的“:无法解析参考 豆“hibernateProperties”而设置的bean属性 “hibernateProperties”;嵌套的例外是 org.springframework.beans.factory.BeanCreationException:错误 创建名为“hibernateProperties”豆:无法解析 参考豆“dialectDetector”,而与键[hibernate.dialect]设置bean属性 “属性”;嵌套的异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为'dialectDetector'的bean:调用init方法 失败;嵌套的异常是 org.springframework.jdbc.support.MetaDataAccessException:错误,而 提取DatabaseMetaData;嵌套的例外是 org.apache.commons.dbcp.SQLNestedException:无法创建 PoolableConnectionFactory(IO例外: “java.io.FileNotFoundException:/var/lib/tomcat7/prodDb.lock.db (拒绝)”;“ /var/lib/tomcat7/prodDb.lock.db“[90031-164]) at java.util.concurrent。Executors $ RunnableAdapter.call(Executors.java:471) at java.util.concurrent.FutureTask.run(FutureTask.java:262)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:615) 在java.lang.Thread.run(Thread.java:744)

BUILD配置文件:

// locations to search for config files that get merged into the main config; 
// config files can be ConfigSlurper scripts, Java properties files, or classes 
// in the classpath in ConfigSlurper format 

// grails.config.locations = [ "classpath:${appName}-config.properties", 
//        "classpath:${appName}-config.groovy", 
//        "file:${userHome}/.grails/${appName}-config.properties", 
//        "file:${userHome}/.grails/${appName}-config.groovy"] 

// if (System.properties["${appName}.config.location"]) { 
// grails.config.locations << "file:" + System.properties["${appName}.config.location"] 
// } 

grails.project.groupId = appName // change this to alter the default package name and Maven publishing destination 
grails.mime.file.extensions = true // enables the parsing of file extensions from URLs into the request format 
grails.mime.use.accept.header = false 
grails.mime.types = [ 
    all:   '*/*', 
    atom:   'application/atom+xml', 
    css:   'text/css', 
    csv:   'text/csv', 
    form:   'application/x-www-form-urlencoded', 
    html:   ['text/html','application/xhtml+xml'], 
    js:   'text/javascript', 
    json:   ['application/json', 'text/json'], 
    multipartForm: 'multipart/form-data', 
    rss:   'application/rss+xml', 
    text:   'text/plain', 
    xml:   ['text/xml', 'application/xml'] 
] 

// URL Mapping Cache Max Size, defaults to 5000 
//grails.urlmapping.cache.maxsize = 1000 

// What URL patterns should be processed by the resources plugin 
grails.resources.adhoc.patterns = ['/images/*', '/css/*', '/js/*', '/plugins/*'] 

// The default codec used to encode data with ${} 
grails.views.default.codec = "none" // none, html, base64 
grails.views.gsp.encoding = "UTF-8" 
grails.converters.encoding = "UTF-8" 
// enable Sitemesh preprocessing of GSP pages 
grails.views.gsp.sitemesh.preprocess = true 
// scaffolding templates configuration 
grails.scaffolding.templates.domainSuffix = 'Instance' 

// Set to false to use the new Grails 1.2 JSONBuilder in the render method 
grails.json.legacy.builder = false 
// enabled native2ascii conversion of i18n properties files 
grails.enable.native2ascii = true 
// packages to include in Spring bean scanning 
grails.spring.bean.packages = [] 
// whether to disable processing of multi part requests 
grails.web.disable.multipart=false 

// request parameters to mask when logging exceptions 
grails.exceptionresolver.params.exclude = ['password'] 

// configure auto-caching of queries by default (if false you can cache individual queries with 'cache: true') 
grails.hibernate.cache.queries = false 

environments { 
    development { 
     grails.logging.jul.usebridge = true 
    } 
    production { 
     grails.logging.jul.usebridge = true 
     grails.serverURL = "http://100.117.40.30:8080/MyApp" 
    } 
} 

// log4j configuration 
log4j = { 
    // Example of changing the log pattern for the default console appender: 
    // 
    //appenders { 
    // console name:'stdout', layout:pattern(conversionPattern: '%c{2} %m%n') 
    //} 

    error 'org.codehaus.groovy.grails.web.servlet',  // controllers 
      'org.codehaus.groovy.grails.web.pages',   // GSP 
      'org.codehaus.groovy.grails.web.sitemesh',  // layouts 
      'org.codehaus.groovy.grails.web.mapping.filter', // URL mapping 
      'org.codehaus.groovy.grails.web.mapping',  // URL mapping 
      'org.codehaus.groovy.grails.commons',   // core/classloading 
      'org.codehaus.groovy.grails.plugins',   // plugins 
      'org.codehaus.groovy.grails.orm.hibernate',  // hibernate integration 
      'org.springframework', 
      'org.hibernate', 
      'net.sf.ehcache.hibernate' 
} 

UPDATE

DATASOURCE.GROVVY

dataSource { 
    pooled = true 
    driverClassName = "org.h2.Driver" 
    username = "sa" 
    password = "" 
} 
hibernate { 
    cache.use_second_level_cache = true 
    cache.use_query_cache = false 
    cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' 
} 
// environment specific settings 
environments { 
    development { 
     dataSource { 
      dbCreate = "create-drop" // one of 'create', 'create-drop', 'update', 'validate', '' 
      url = "jdbc:h2:mem:devDb;MVCC=TRUE;LOCK_TIMEOUT=10000" 
     } 
    } 
    test { 
     dataSource { 
      dbCreate = "update" 
      url = "jdbc:h2:mem:testDb;MVCC=TRUE;LOCK_TIMEOUT=10000" 
     } 
    } 
    production { 
     dataSource { 
      dbCreate = "update" 
      url = "jdbc:h2:prodDb;MVCC=TRUE;LOCK_TIMEOUT=10000" 
      pooled = true 
      properties { 
       maxActive = -1 
       minEvictableIdleTimeMillis=1800000 
       timeBetweenEvictionRunsMillis=1800000 
       numTestsPerEvictionRun=3 
       testOnBorrow=true 
       testWhileIdle=true 
       testOnReturn=true 
       validationQuery="SELECT 1" 
      } 
     } 
    } 
} 
+1

实际上您应该共享您的'DataSource.groovy'。看起来有一个权限问题试图访问文件(或文件数据库)'/ var/lib/tomcat7/prodDb.lock.db'。 – dmahapatro

+0

我已更新'DataSource.groovy'的帖子。 – Illep

+0

是的应用程序正在寻找名为prodDb的h2数据库。将生产环境下的该部分替换为您拥有的实际数据库或数据源或JNDI名称。 – dmahapatro

回答

8

删除您的DataSource.groovy文件中,并做了grails clean,这将禁用数据源基于默认的文件后,重建WAR

目前,它正试图以创建一个数据库文件系统但由于您没有权限而无法执行

+0

不适用于我,如果我删除DataSource.groovy我得到一个'hibernateBean'没有发现异常,是否有另一种解决方法?为什么新创建的Grails项目表现如此呢? – tonix

+0

我没有删除该文件,但评论其内容。它为我工作。 – kunde