0

我有一个包含数千个测试的大型多模块 Maven 项目。每个测试使用 SpringApplicationContext 注解加载 DAO、服务等。我的 unitils 配置如下所示:

database.driverClassName=org.hsqldb.jdbcDriver
database.url=jdbc:hsqldb:file:mytestdb
database.schemaNames=PUBLIC
database.userName=sa
database.password=
database.dialect=hsqldb
unitils.modules=database,dbunit,hibernate,inject,spring
# custom version of HsqldbDbSupport which calls "SET REFERENTIAL_INTEGRITY FALSE"
org.unitils.core.dbsupport.DbSupport.implClassName.hsqldb=my.company.unitils.HsqldbDbSupport
org.dbunit.dataset.datatype.IDataTypeFactory.implClassName.hsqldb=org.dbunit.ext.hsqldb.HsqldbDataTypeFactory
org.unitils.dbmaintainer.structure.ConstraintsDisabler.implClassName=org.unitils.dbmaintainer.structure.impl.DefaultConstraintsDisabler
# custom version of CleanInsertLoadStrategy which calls "DatabaseUnitils.disableConstraints();"
DbUnitModule.DataSet.loadStrategy.default=my.company.unitils.DataSetLoadStrategy
HibernateModule.configuration.implClassName=org.hibernate.cfg.AnnotationConfiguration
dbMaintainer.disableConstraints.enabled=true
dbMaintainer.cleanDb.enabled=true
dbMaintainer.generateDataSetStructure.enabled=false
dataSetStructureGenerator.xsd.dirName=target/xsd
dbMaintainer.autoCreateExecutedScriptsTable=true
updateDataBaseSchema.enabled=false
dbMaintainer.fromScratchEnabled=true

我的休眠配置如下所示:

hibernate.hbm2ddl.auto=update
hibernate.show_sql=false
hibernate.format_sql=false
hibernate.dialect=org.hibernate.dialect.HSQLDialect
hibernate.connection.autocommit=false
hibernate.cache.provider_class=org.hibernate.cache.NoCacheProvider
hibernate.cache.use_query_cache=false
hibernate.cache.use_second_level_cache=false
hibernate.cache.use_structured_entries=false
hibernate.generate_statistics=false

当我运行测试时,分配给堆的 2GB 最终会填满。Permgen 达到大约 400MB。查看堆转储,charjava.lang.Stringjava.lang.String[]占用了大约 40% 的实例总数。

当我抽查其中一些实例时,GC 根可以追溯到:

  • Spring 上下文管理器(以上下文 XML 提取的形式)
  • SessionFactory(以查询的形式)

我想优化这两件事,我认为它们分别是由以下原因引起的:

  • 每个测试都有一个@SpringApplicationContext 注解
  • 每个测试还使用 unitils @DataSet 注释来加载该测试的数据。

注意,我使用 jdbc:hsqldb:file 从堆中卸载一些数据(即,而不是使用 jdbc:hsqldb:mem)

版本:
hsqldb 1.8.0.7
Spring 3.0.4.RELEASE unitils
3.1

PS有 1500+ 评分的人可以用“unitils”标记这个问题吗?

4

1 回答 1

1

如果内存被存储在数据库中的数据占用,可以让数据库使用基于磁盘的表来减少内存使用。这可以在数据库 URL 上指定:

database.url=jdbc:hsqldb:file:mytestdb;hsqldb.default_table_type=cached

于 2010-09-24T16:04:17.353 回答