龙空技术网

如何解决内存溢出问题的?

刘丞渊 139

前言:

如今兄弟们对“数据库数据溢出”大致比较重视,朋友们都想要分析一些“数据库数据溢出”的相关内容。那么小编在网上收集了一些关于“数据库数据溢出””的相关内容,希望姐妹们能喜欢,看官们一起来学习一下吧!

内存溢出的原因有很多种:

1.内存中加载的数据量过于庞大,如一次从数据库取出过多数据;

2.集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;

3.代码中存在死循环或死循环产生过多重复的对象实体;

4.使用的第三方软件中的BUG;

5.启动参数内存值设定的过小;

6.死锁

内存溢出的解决方案:

1、就是修改JVM启动参数,直接增加内存。

2、检查错误日志,查看“OutOfMemory”错误前是否有其它异常或错误。

3、使用jconsole来查看死锁

4、对代码进行走查和分析

1.检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式进行查询。

2.检查代码中是否有死循环或递归调用。

3.检查是否有大循环重复产生新对象实体。

4.检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式查询。

5.检查List、MAP等集合对象是否有使用完后,未清除的问题。List、MAP等集合对象会始终存有对对象的引用,使得这些对象不能被GC回收。

标签: #数据库数据溢出