Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/320.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/spring-mvc/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 部署Grails应用程序时出错-初学者_Java_Spring Mvc_Grails_Groovy - Fatal编程技术网

Java 部署Grails应用程序时出错-初学者

Java 部署Grails应用程序时出错-初学者,java,spring-mvc,grails,groovy,Java,Spring Mvc,Grails,Groovy,我在部署Grails应用程序时遇到问题。一切都在本地测试环境中工作 错误 [localhost-startStop-1]错误上下文。GrailContextLoader-错误 初始化应用程序:创建名为的bean时出错 “transactionManagerPostProcessor”:bean初始化失败; 嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 正在创建名为“transactionManager”的bean

我在部署Grails应用程序时遇到问题。一切都在本地测试环境中工作

错误

[localhost-startStop-1]错误上下文。GrailContextLoader-错误 初始化应用程序:创建名为的bean时出错 “transactionManagerPostProcessor”:bean初始化失败; 嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 正在创建名为“transactionManager”的bean:无法解析引用 设置bean属性“sessionFactory”时调用bean“sessionFactory”; 嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 正在创建名为“sessionFactory”的bean:无法解析对的引用 设置bean属性时bean“hibernateProperties” “hibernateProperties”;嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 正在创建名为“hibernateProperties”的bean:无法解析 设置bean属性时对bean“方言检测器”的引用 带有键[hibernate.dial]的“属性”;嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为“方言检测器”的bean:init方法的调用 失败;嵌套异常是 org.springframework.jdbc.support.MetaDataAccessException:运行时出错 提取数据库元数据;嵌套异常是 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:错误 正在创建名为“sessionFactory”的bean:无法解析对的引用 设置bean属性时bean“hibernateProperties” “hibernateProperties”;嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 正在创建名为“hibernateProperties”的bean:无法解析 设置bean属性时对bean“方言检测器”的引用 带有键[hibernate.dial]的“属性”;嵌套异常是 org.springframework.beans.factory.BeanCreationException:错误 创建名为“方言检测器”的bean:init方法的调用 失败;嵌套异常是 org.springframework.jdbc.support.MetaDataAccessException:运行时出错 提取数据库元数据;嵌套异常是 org.apache.commons.dbcp.SQLNestedException:无法创建 PoolableConnectionFactory(IO异常: “java.io.FileNotFoundException:/var/lib/tomcat7/prodDb.lock.db (权限被拒绝)“;”/var/lib/tomcat7/prodDb.lock.db“[90031-164]) 在 Executors$RunnableAdapter.call(Executors.java:471) 在java.util.concurrent.FutureTask.run(FutureTask.java:262)中 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 运行(Thread.java:744)

生成配置文件:

// 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'
}

删除DataSource.groovy文件,并在执行
grails clean
后重建WAR,这将禁用默认的基于文件的数据源


目前,它正在尝试在文件系统上创建数据库,但失败了,因为您没有这样做的权限

您应该实际共享您的
数据源.groovy
。似乎在尝试访问文件(或文件数据库)时出现权限问题。
/var/lib/tomcat7/prodDb.lock.db
。我已使用
数据源更新了帖子。groovy
是的应用程序正在查找名为prodDb的h2 db。用prod中的实际数据库或数据源或JNDI名称替换生产环境下的该部分。顺便说一句,如果您还不知道,但您可以使用grails run app在开发模式下工作,而不是每次都部署该应用。默认情况下,RunApp在8080端口使用嵌入式Tomcat。我暂时不想在我的应用程序中使用DB。我可以把它留空吗?如果我删除DataSource.groovy,我会得到一个
hibernateBean
not found异常,这对我不起作用,还有其他解决方法吗?为什么一个新创建的Grails项目的行为如此?我没有删除该文件,但对其内容进行了注释。这对我有用。
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"
            }
        }
    }
}