一直在做批量测试工具的研发,所谓批量,那么数据量不言而喻了。
什么级别呢,目前本程序就个人测试而言,2199W数据暂时没问题,一次性写入大约九分钟左右。
都是因数据量大,读或写操作,遇到的瓶颈,一言不合就内存溢出,也就是常见的这个:java.lang.OutOfMemoryError: Java heap space。
经验而言,肯定会修改IDEA运行参数,即电脑支持最大内存了,如:-Xms8092m -Xms8092m。
可能有的同学会说了,直接让他在IDE上跑,设定运行jvm参数就好了呀。
试想,如果要给别人使用,肯定要脱离IDE,打包成可执行程序的,才更具易用性。
不能直接让人家在IDE上跑吧,那还是工具嘛,o(╯□╰)o
再来看打包工具jvm参数设置页面,如下:
按照网上很多的说法就是,加大jvm内存设置即可,但将设定jvm参数加入打包中,还是第一次尝试。
这样做的好处是什么?
当执行这个jar包程序,就不需要指定运行参数了。
参考“Allow VM。。。”那一行写的,设置为 -J-Xmx512m至-J-Xmx8192m,一跑还是内存溢出,明显这个方法无效,直接废弃掉。
参考MyEclipse中设置VM的方式,设置成-XX:PermSize=512M 至 -XX:MaxPermSize=8192M,再一跑,还是一样内存溢出,一样的,这个方法也废弃掉。
-Xms4096m -Xmx8192m
再次执行打包程序,就正常了,且稳定奔放,没有再报错,问题解决。