写点什么

【YashanDB 知识库】kettle 同步大表提示 java 内存溢出

作者:YashanDB
  • 2024-12-16
    广东
  • 本文字数:411 字

    阅读完需:约 1 分钟

【问题分类】数据导入导出

【关键字】数据同步,kettle,数据迁移,java 内存溢出

【问题描述】kettle 同步大表提示 ERROR:could not create the java virtual machine!

【问题原因分析】java 内存溢出

【解决/规避方法】

①增加 JVM 的堆内存大小。编辑 Spoon.bat,增加堆大小到 2GB,如:

if "%PENTAHO_DI_JAVA_OPTIONS%"=="" set PENTAHO_DI_JAVA_OPTIONS="-Xms512m" "-Xmx512m" "-XX:MaxPermSize=256m" "-Dsun.jnu.encoding=UTF8"
#其中-Xms是初始堆大小,-Xmx是最大堆大小。
复制代码

②优化 Kettle 转换。检查步骤是否有优化空间,例如通过调整批量大小、优化数据库查询、减少不必要的步骤等。

③通过 PARALLELISM 参数的值合理设置并行线程数,如:

time PENTAHO_DI_JAVA_OPTIONS=-DPARALLELISM=4 sh /home/kettle/data-integration/pan.sh -file=/home/kettle/data-integration/test/dir_ktr1/public.T1.k
tr > /home/kettle/data-integration/test/logs1/public.T1.log
复制代码

【影响范围】所有版本

【修复版本】-

发布于: 刚刚阅读数: 3
用户头像

YashanDB

关注

全自研国产新型大数据管理系统 2022-02-15 加入

还未添加个人简介

评论

发布
暂无评论
【YashanDB知识库】kettle同步大表提示java内存溢出_数据库_YashanDB_InfoQ写作社区