部署Grails应用程序时出错 - 初学者 [英] Error deploying Grails application - Beginner
问题描述
我在部署Grails应用程序时遇到问题。一切工作在本地测试环境。
错误
初始化应用程序:错误创建名为
的事务bean'transactionManagerPostProcessor':Bean初始化失败;
嵌套异常是
org.springframework.beans.factory.BeanCreationException:错误
创建名为'transactionManager'的bean:在设置bean属性时无法将引用
解析为bean'sessionFactory' '的sessionFactory';
嵌套的异常是
org.springframework.beans.factory.BeanCreationException:错误
创建名为'sessionFactory'的bean:无法在设置bean属性时解析对
的引用'bibernate'hibernateProperties'
'hibernateProperties';嵌套异常是
org.springframework.beans.factory.BeanCreationException:错误
创建名为'hibernateProperties'的bean:在设置bean属性
时无法解析
引用bean'dialectDetector'使用键[hibernate.dialect]的'属性';嵌套异常是
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
(Permission denied);/var/lib/tomcat7/prodDb.lock.db[90031-164])
org.springframework.beans.factory.BeanCreationException:Error
创建名为'transactionManagerPostProcessor'的bean:
初始化bean失败;嵌套的异常是
org.springframework.beans.factory.BeanCreationException:错误
创建名为'transactionManager'的bean:在设置bean属性'sessionFactory'时无法将引用
解析为bean'sessionFactory';
嵌套的异常是
org.springframework.beans.factory.BeanCreationException:错误
创建名为'sessionFactory'的bean:无法在设置bean属性时解析对
的引用'bibernate'hibernateProperties'
'hibernateProperties';嵌套异常是
org.springframework.beans.factory.BeanCreationException:错误
创建名为'hibernateProperties'的bean:在设置bean属性
时无法解析
引用bean'dialectDetector'使用键[hibernate.dialect]的'属性';嵌套异常是
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
(Permission denied);/var/lib/tomcat7/prodDb.lock.db[90031-164])
at
java.util.concurrent.Executors $ RunnableAdapter。调用(Executors.java:471)
在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)$ b $在java.lang.Thread.run(Thread.java:744)
建立配置文件:
//位置搜索合并到主配置中的配置文件;
//配置文件可以是ConfigSlurper脚本,Java属性文件或类
//在ConfigSlurper格式的类路径中
// 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 //改变它以改变默认值包名称和Maven发布目标
grails.mime.file.extensions = true //允许将URL中的文件扩展名解析为请求格式
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映射缓存最大大小,默认为5000
//grails.urlmapping.cache.maxsize = 1000
/ /资源插件应该处理哪些URL模式
grails.resources.adhoc.patterns = ['/ images / *','/ css / *','/ js / *','/ plugins / * ']
//使用$ {}
编码数据的默认编解码器grails.views.default.codec =none// none,html,base64
grails .views.gsp.encoding =UTF-8
grails.converters.encoding =UTF-8
//启用Sitemesh预处理GSP页面
grails.views.gsp.sitemesh .preprocess = true
//脚手架模板配置
grails.scaffolding.templates.domainSuffix ='实例'
//设置为false以使用新的Grails 1.2 JSONBuilder渲染方法
grails.json.legacy.builder = false
//启用native2ascii转换i18n属性文件
grails.enable.native2ascii = true
//包含在Spring中的包bean扫描
gra ils.spring.bean.packages = []
//是否禁止处理多部分请求
grails.web.disable.multipart = false
//请求参数在记录异常时掩码
grails.exceptionresolver.params.exclude = ['password']
//默认情况下配置查询的自动缓存(如果为false,可以使用缓存缓存单个查询:true')
grails.hibernate.cache.queries = false
environments {
development {
grails.logging.jul.usebridge = true
}
生产{
grails.logging.jul.usebridge = true
grails.serverURL =http://100.117.40.30:8080/MyApp
}
}
// log4j配置
log4j = {
//更改默认控制台appender的日志模式示例:
//
// appenders {
// console name:'stdout',layout:pattern(conversionPattern:'%c {2}%m%n')
//}
error' org.code haus.groovy.grails.web.servlet',//控制器
'org.codehaus.groovy.grails.web.pages',// GSP
'org.codehaus.groovy.grails.web。 sitemesh',//布局
'org.codehaus.groovy.grails.web.mapping.filter',// URL映射
'org.codehaus.groovy.grails.web.mapping',// URL映射
'org.codehaus.groovy.grails.commons',//核心/类加载
'org.codehaus.groovy.grails.plugins',//插件
'org.codehaus .groovy.grails.orm.hibernate',// hibernate集成
'org.springframework',
'org.hibernate',
'net.sf.ehcache.hibernate'
}
更新
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'
}
//环境特定设置
环境{
开发{
dataSource {
dbCreate = create-drop//创建'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
}
生产{
dataSource {
dbCreate =update
url =jdbc:h2:prodDb; MVCC = TRUE; LOCK_TIMEOUT = 10000
pooled = true
属性{
maxActive = -1
minEvictableIdleTimeMillis = 1800000
timeBetweenEvictionRunsMillis = 1800000
numTestsPerEvictionRun = 3
testOnBorrow = true
testWhileIdle = true
testOnReturn = true
validationQuery =SELECT 1
$ div class =h2_lin>解决方案 删除DataSource.groovy文件并在执行 grails clean
之后重建WAR,这将禁用基于默认文件的数据源
目前它正在试图在文件系统上创建一个数据库,但由于您没有权限这么做而失败。
I am having issues deploying a Grails application. Everything works in the local test environment.
ERROR
[localhost-startStop-1] ERROR context.GrailsContextLoader - Error
initializing the application: Error creating bean with name
'transactionManagerPostProcessor': Initialization of bean failed;
nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'transactionManager': Cannot resolve reference
to bean 'sessionFactory' while setting bean property 'sessionFactory';
nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'sessionFactory': Cannot resolve reference to
bean 'hibernateProperties' while setting bean property
'hibernateProperties'; nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'hibernateProperties': Cannot resolve
reference to bean 'dialectDetector' while setting bean property
'properties' with key [hibernate.dialect]; nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'dialectDetector': Invocation of init method
failed; nested exception is
org.springframework.jdbc.support.MetaDataAccessException: Error while
extracting DatabaseMetaData; nested exception is
org.apache.commons.dbcp.SQLNestedException: Cannot create
PoolableConnectionFactory (IO Exception:
"java.io.FileNotFoundException: /var/lib/tomcat7/prodDb.lock.db
(Permission denied)"; "/var/lib/tomcat7/prodDb.lock.db" [90031-164])
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'transactionManagerPostProcessor':
Initialization of bean failed; nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'transactionManager': Cannot resolve reference
to bean 'sessionFactory' while setting bean property 'sessionFactory';
nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'sessionFactory': Cannot resolve reference to
bean 'hibernateProperties' while setting bean property
'hibernateProperties'; nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'hibernateProperties': Cannot resolve
reference to bean 'dialectDetector' while setting bean property
'properties' with key [hibernate.dialect]; nested exception is
org.springframework.beans.factory.BeanCreationException: Error
creating bean with name 'dialectDetector': Invocation of init method
failed; nested exception is
org.springframework.jdbc.support.MetaDataAccessException: Error while
extracting DatabaseMetaData; nested exception is
org.apache.commons.dbcp.SQLNestedException: Cannot create
PoolableConnectionFactory (IO Exception:
"java.io.FileNotFoundException: /var/lib/tomcat7/prodDb.lock.db
(Permission denied)"; "/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)
at java.lang.Thread.run(Thread.java:744)
BUILD CONFIG FILE :
// 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"
}
}
}
}
解决方案 Remove your DataSource.groovy file and rebuild the WAR after doing a grails clean
, which will disable the default file based data source
Currently it is trying to create a database on the file system but failing because you do not have the permission to do so
这篇关于部署Grails应用程序时出错 - 初学者的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!