Sri*_*ini 6 java heap-memory liquibase
当我尝试从 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
Run Code Online (Sandbox Code Playgroud)
我尝试通过在 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
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6317 次 |
| 最近记录: |