weblogic连接池设置和监控
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{
//***在这里关闭连接***///
}
以下文章点击率最高
Loading…