当前位置:网站首页 > 数据科学与大数据 > 正文

druid数据库连接池不释放(druid数据库连接池一直满)



内存溢出:是指要求所需分配的内容超出系统能给的。

内存泄漏:是指使用过的内存空间没有被及时释放,长时间占用内存。最终导致内存空间不足。

内存溢出的原因及解决方法:

内存溢出的解决方法:

1.修改JVM启动参数,直接增加内存。(-Xms,-Xmx参数一定不要忘记加。)

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

3.对代码进行走查和分析,找出可能发生内存溢出的位置。

4.使用内存查看工具动态查看内存使用情况

对代码分析找出可能发生内存溢出的位置, 可能出现的几种情况:

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

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

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

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

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

到此这篇druid数据库连接池不释放(druid数据库连接池一直满)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • jdbc连接oracle加密传输(jdbc连接oracle数据库代码)2026-05-10 19:54:10
  • orecal数据库安装(orcal数据库安装教程)2026-05-10 19:54:10
  • 数据库端口号怎么查看的(数据库端口号怎么查看的啊)2026-05-10 19:54:10
  • 英文全文数据库有哪些内容(英文全文数据库有哪些内容组成)2026-05-10 19:54:10
  • mysql主键的数据类型(mysql主键用什么类型)2026-05-10 19:54:10
  • 数据库基础知识(mysql数据库基础知识)2026-05-10 19:54:10
  • 达梦连接数据库jdbc(达梦连接数据库6001)2026-05-10 19:54:10
  • 中文全文数据库有哪些cssci(中文期刊全文数据库有哪些)2026-05-10 19:54:10
  • 为自动驾驶技术标注数据集(自动驾驶 数据集)2026-05-10 19:54:10
  • cpu参数对比工具在哪(cpu数据对比图)2026-05-10 19:54:10
  • 全屏图片