今天一个网友问了我一个问题:
需要给这个接口中写义工xml串(4w条),人家接口返回0或者1
问题是:5千条正常传送,1w条就报内存溢出 .
问题是:5千条正常传送,1w条就报内存溢出 .
报java.lang.OutOfMemoryError: Java heap space
错误.
建议解决方法:
1.设OutOfMemory的异常断点,看出错时jvm里的堆栈情况.
2.增大内存.(可是他说内存是2G的,服务器内存8G,依旧报错)
3.分页给数据.(可是他说不行,必须一次性给1W条以上的数据)
真心的建议还是从优化程序的设计入手.解决根本问题.最终他还是采纳了我的建议.
可能性:
a.有和全局的List在整个抽取中不被释放;
b.日志文件不是批次写入,而时所有都结束后一次写入,无论总文件有多大.
问题就好比我们一顿饭多次点没有关系,天天这么吃就会张胖一样.
所以程序中特别是全局或是static的东西要很是留意.

本文讨论了一个面临内存溢出问题的大数据处理场景,分析了可能的原因并提出了优化建议,包括设置内存异常断点、调整内存配置、优化程序设计等方法。重点在于从根本上解决内存使用效率问题。

被折叠的 条评论
为什么被折叠?



