A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 蒋欣琦 中级黑马   /  2012-11-2 12:09  /  1364 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

weblogic 的数据库连接数目在程序运行中不断增长,最后连接数目超过最大数,导致weblogic服务关闭,如何解决?

评分

参与人数 1技术分 +1 收起 理由
谭立文 + 1

查看全部评分

2 个回复

倒序浏览
1.在操作完数据库要关闭数据库连接。
2.尽量不要返回结果集Resultset, 可以返回Vector(一个字段)、Hashtable(多个字段),这样可以在javabean中关闭数据库。
3.如果javabean中返回的是结果集(Resultset),也可以在javaBean中写一个connectDB(连接数据库)、closeDB(关闭数据库)的方法,然后jsp里面调用connectDB(),建立数据库连接,同时就可以对数据库进行操作了,操作数据库完毕,可以通过closeDB() 来关闭数据库

评分

参与人数 1技术分 +1 收起 理由
谭立文 + 1

查看全部评分

回复 使用道具 举报
原因:

  在操作完数据库后,没有关闭数据库连接;或者是返回结果集(Resultset),而无法在JSP中关闭数据库连接。

  解决方法:

  1.在操作完数据库要关闭数据库连接。

  2.尽量不要返回结果集Resultset, 可以返回Vector(一个字段)、Hashtable(多个字段),这样可以在javabean中关闭数据库。

  3.如果javabean中返回的是结果集(Resultset),也可以在javaBean中写一个connectDB(连接数据库)、closeDB(关闭数据库)的方法,然后jsp里面调用connectDB(),建立数据库连接,同时就可以对数据库进行操作了,操作数据库完毕,可以通过closeDB() 来关闭数据库。

  问题2:

  在运行某一个JSP程序的时候,weblogic 的内存陡然增长,而且居高不下。最终导致weblogic 内存不足,甚至宕机。

  原因:

  过度使用内存。

  解决方法:

  1.由于数据量比较大,在对字符串进行操作的时候,使用 + 进行字符串连接,而相信大家对String都非常熟悉,我们也经常要用它来做字符串的连接什么的,例如:

  String a =b+c file://b,c 都是String

  但是在实际的编译中却是这样:
  1. String a=new StringBuffer().append(b).append(c).toString()
复制代码
显然,在一个简单的语句中却意外的多生成了2个对象:

  .StringBuffer()

  .toString返回的一个String

  我们比较一下这两段程序的性能:

  程序片断一:
  1. StringBuffer s=new StringBuffer(); long start = System.currentTimeMillis(); for (int i=0;i<10000;i++){ s1+="a"; } long stop = System.currentTimeMillis(); System.out.println(stop-start);
复制代码
程序片断二:
  1. StringBuffer s=new StringBuffer(10000);// long start=System.currentTimeMillis();  for (int i=0;i<10000;i++){ s.append("a");  } long stop=System.currentTimeMillis(); System.out.println(stop-start);
复制代码
比较一下结果,差距很明显。

  至于为什么String的连接这么做,因为String无法直接改变其长度,而必须采用StringBuffer的用法。

  因此建议使用StringBuffer 的append 方法来进行字符串相连。

  2.在解决这个问题的时候,我也尝试使用上面的方法,效果并不是很明显(消耗内存上)。后来在显示大量数据的时候,避免字符串相连的步骤,而直接使用out.println(),直接输出。

  问题3:

  Java并不阻止程序占用过多的内存,当对象向堆所请求的内存不足时,垃圾收集器(Garbage Collector)就会自动启动,释放那些引用数为零的对象所占用的内存,Java也不会自动释放无用的对象的引用,如果程序忘记释放指向对象的引用,则程序运行时的内存随着时间的推移而增加,发生所谓内存泄漏(memory leaks),创建对象不但消耗CPU的时间和内存,同时,为释放对象内存JVM需不停地启动垃圾收集器(Garbage Collector),这也会消耗大量的CPU时间。

  解决方法:

  由于在运行一段时间jsp程序后,weblogic 的内存会有一个缓慢的增长,这样也会导致内存溢出,为了避免这总现象的出现,最终的解决方法是: 编写一个servlet程序,在启动服务器的时候,启动一个这个servlet,每隔20分钟运行在服务器端运行一次,来定时回收内存。

  问题4:

  log文件里面的调试信息没有注释去掉。

  解决方法:

  在程序通过后,尽量把调试的信息注释去掉。

  同时在捕捉错误的时候要写明程序名称,方便查找,这一点做的还不够。

  最好能写一个记录log的方法,以便程序调用。

  问题5:

  改善性能,提高速度。

  具体实例:

  我们再来看一个有关Vector类的代码片段:
  1. for(int I=0; I
复制代码
如果v包含100,000个元素,这个代码片段将调用v.size()方法100,000次。虽然size方法是一个简单的方法,但它仍旧需要一次方法调用的开销,至少JVM需要为它配置以及清除堆栈环境。在这里,for循环内部的代码不会以任何方式修改Vector类型对象v的大小,因此上面的代码最好改写成下面这种形式:



回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马