当我尝试从 DB2 数据库生成 SQL 数据时,遇到 Java 堆空间问题。大约有 25 个表,大约 1000 条记录。
我使用以下脚本生成变更集数据:
C:\liquibase-3.0.2-bin>liquibase --driver=com.ibm.db2.jcc.DB2Driver \
--classpath="C:\db2jcc.jar" \
--changeLogFile="C:\Liquibase Release\liqui_MYDB_MYSCHEMA_Data.xml" \
--url="jdbc:db2://__ip__here__:9008/MYDB" \
--username="user" \
--password="12345" \
--defaultSchemaName="MYSCHEMA" \
--diffTypes=data \
generateChangeLog
我尝试通过在 liquibase.bat 文件中设置 JAVA_OPTS 来增加内存,但这没有产生任何解决方案:
set JAVA_OPTS="-XX:MaxPermSize=1024m"
set JAVA_OPTS="-Xms512m -Xmx1024m"
您不应该遇到 MaxPermSize,因此只需设置一个更大的 Xmx 标志就足够了。
添加以下内容也可能有所帮助--dataOutputDirectory=DIR_YOU_WANT
旗帜。这将导致 Liquibase 以 CSV 文件输出数据,创建该文件所需的内存消耗较少。生成的 XML+CSV 通常也比巨大的 XML 文件更易于管理
就像是:
C:\liquibase-3.0.2-bin>liquibase \
--driver=com.ibm.db2.jcc.DB2Driver \
--classpat h="C:\db2jcc.jar" \
--changeLogFile="C:\Liquibase Release\liqui_MYDB_MYSCHEMA_Data.xml" \
--url="jdbc:db2://__ip__here__:9008/MYDB" \
--username="user" \
--password="12345" \
--defaultSchemaName="MYSCHEMA" \
--diffTypes=data \
--dataOutputDirectory=C:\Liquibase Release\liqui_MYDB_MYSCHEMA_Data.out \
generateChangeLog
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)