weblogic连接池设置和监控

原创 2016年10月27日 15:50:49

1.weblogic的连接池的线程数可以设置初始值和最大值。
连接池,把短连接变成了长连接。这样减少了网络IO的消耗,设置了连接池之后可以在操作系统上看到如下信息:

iostat -natpl | grep 3306

tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45899      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45886      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45851      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45859      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45836      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45887      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45898      TIME_WAIT   -                   
tcp        0      0 ::ffff:10.10.101.2:3306     ::ffff:222.74.214.122:9660  ESTABLISHED -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45850      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:7001       ::ffff:127.0.0.1:46475      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45863      TIME_WAIT   -                   
tcp        0      0 ::1:7001                    ::1:37445                   TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45888      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45861      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45873      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45840      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45860      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45835      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45891      TIME_WAIT   -                   
tcp        0      0 ::1:56622                   ::1:42622                   TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45866      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45871      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45876      TIME_WAIT   -                   
tcp        0      0 ::ffff:127.0.0.1:3306       ::ffff:127.0.0.1:45892      TIME_WAIT   -

在数据库中可以看到:

show full processlist;

| 2075 | root | localhost:44194 | coa  | Sleep   |  368 |       | NULL                  |
| 2076 | root | localhost:44195 | coa  | Sleep   |  366 |       | NULL                  |
| 2077 | root | localhost:44196 | coa  | Sleep   |  365 |       | NULL                  |
| 2078 | root | localhost:44197 | coa  | Sleep   |  364 |       | NULL                  |
| 2079 | root | localhost:44198 | coa  | Sleep   |  362 |       | NULL                  |
| 2080 | root | localhost:44199 | coa  | Sleep   |  361 |       | NULL                  |
| 2081 | root | localhost:44200 | coa  | Sleep   |  359 |       | NULL                  |
| 2082 | root | localhost:44201 | coa  | Sleep   |  358 |       | NULL                  |
| 2083 | root | localhost:44202 | coa  | Sleep   |  356 |       | NULL                  |
| 2084 | root | localhost:44203 | coa  | Sleep   |  355 |       | NULL                  |
| 2085 | root | localhost:44204 | coa  | Sleep   |  353 |       | NULL                  |
| 2086 | root | localhost:44205 | coa  | Sleep   |  352 |       | NULL                  |
| 2087 | root | localhost:44206 | coa  | Sleep   |  350 |       | NULL                  |
| 2088 | root | localhost:44207 | coa  | Sleep   |  348 |       | NULL                  |
| 2089 | root | localhost:44208 | coa  | Sleep   |  347 |       | NULL                  |
| 2090 | root | localhost:44209 | coa  | Sleep   |  345 |       | NULL                  |
| 2091 | root | localhost:44210 | coa  | Sleep   |  344 |       | NULL                  |
| 2092 | root | localhost:44211 | coa  | Sleep   |  342 |       | NULL                  |
| 2093 | root | localhost:44212 | coa  | Sleep   |  340 |       | NULL                  |
| 2094 | root | localhost:44213 | coa  | Sleep   |  339 |       | NULL                  |
| 2095 | root | localhost:44214 | coa  | Sleep   |  337 |       | NULL   

如,初始容量:5 最大容量:20
最大的容量,也就是说可以提供多少个连接,就是说数据库这个房子总共有多少个门,那么这个实例里就是有20个门。
初始值也就是说平时就给程序连接开几个门,这几个门始终开着,连接过来的时候,可以不用再去开辟新的连接。
2.非活动连接超时时间
如果单设置了最大值和最小值而没有设置此值,那么如果遇到程序不释放连接、在监控中是看不到泄漏的连接的。
这次设置了10秒。之后在weblogic的日志里看到了自动强制释放连接的记录

<Oct 27, 2016 3:50:27 PM CST> <Warning> <JDBC> <BEA-001153> <Forcibly releasing inactive/harvested connection 

"weblogic.jdbc.wrapper.PoolConnection_com_mysql_jdbc_JDBC4Connection@280" 

在数据库日志里看到了weblogic过来杀进程的信息:

2700 Query     /* mysql-connector-java-commercial-5.1.17 ( Revision: ${bzr.revision-id} ) */
     SHOW VARIABLES WHERE Variable_name ='language' 
OR Variable_name = 'interactive_timeout' OR Variable_name = 'wait_timeout'
 OR Variable_name = 'character_set_client' OR Variable_name = 'character_set_connection' 
 OR Variable_name = 'character_set_server' OR Variable_name = 'tx_isolation' 
 OR Variable_name = 'lower_case_table_names' 
OR Variable_name = 'sql_mode' OR Variable_name = 'query_cache_type'
 OR Variable_name = 'query_cache_size' 
 OR Variable_name = 'init_connect'

3、泄漏连接
在weblogic的连接池监控中,可以定义要监控的选项,默认是没有几项的,一般是监控最大可用数量、最大活动连接计数 、 泄漏连接计数、 其中泄露的连接计数就是常说的不释放的连接所致。
解决代码如下:

Connection connection=null;
     try{
         try{
           connection = getConnectionByJndi(...);
         }catch(Exception e){
           return ;
         }

     }catch(Exception e){}
     finally{
       //***在这里关闭连接***///
     }
版权声明:本文为博主原创文章,未经博主允许不得转载。

weblogic数据库连接池参数配置详解

比较容易混淆的参数解释   1:Inactive Connection Timeout 这个参数很重要,是10以后的版本新加的,9版本没有,一般情况建议不要开启该参数,即使开启也尽可能要把数值设...

weblogic10数据源(连接池)配置

在weblogic中配置数据源比在tomcat中配置数据源要麻烦一些,但是性能要强大得多! 1.        打开浏览器输入控制台url,进入控制台进行管理(http://82.XXX.XXX.XX...

WebLogic:配置连接池

WebLogic继承了绝大多数数据库的驱动。 在服务器中,连接池是以JNDI的方式提供的。   使用控制台创建一个连接池 新建一个一般的数据源。 建立一个Oracle...

WebLogic配置JDBC数据源

1. 概述 最近针对某银行的web项目上线,部署在他们的weblogic机器上,根据银行的规范,部署在WebLogic Server上的应用程序如果需要访问数据库,原则上需要通过WebLogic提供的...

WebLogic10中配置数据库连接池

1. 打开wls控制台,输入用户名和密码(默认为weblogic/weblogic) http://localhost:7001/console 2. 正在Domain Structrue...

记一次Weblogic连接池泄露的修复过程

问题描述从weblogic控制台上,可以看到连接泄露已经达到了6K+,应用已经变得非常不稳定。根据以往的经验,连接池出现泄漏情况一般为代码申请了一个数据库连接,使用后未正常关闭,导致连接一致被占用,应...

Weblogic如何通过JMX监控JDBC资源(数据源)数据

今天一同事问到了我这个问题,由于本人对Weblogic不太了解,所以决定先尝试一下。     新建一个数据源,通过传统的Jconsole连接(需要在Weblogic启动参数中配置jmx参数,这里省略)...

weblogic Connection Leak 连接池泄漏问题解决

如果程序有问题, weblogic 里 Maximum Capacity 设置多大,都会泄漏的。你设置50 Active Connections Current Count变为50,设置为100,它变...

Weblogic 数据源 连接池占满的一种解决思路

连接池占满比然后会有数据库连接泄露或者未释放。如果一句一句去找哪个sql出了问题是比较麻烦的特别是在别人的代码上找,这个时候可以点击Weblogic控制台,进入环境-----服务器选择服务  点击监视...

weblogic连接池重连机制不一定靠得住

现场的weblogic报警,日志报错:      ORA-27102: out of memory Linux-x86_64 Error: 12: Cannot allocate memory Add...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:weblogic连接池设置和监控
举报原因:
原因补充:

(最多只允许输入30个字)