让你的C3P0配置更健全

一:先贴上代码:

 

二:进入mysql,type:

SHOW GLOBAL VARIABLES LIKE '%_timeout';

找到:A: interactive_timeout     28800 (8小时)

         B: wait_timeout               28800

解释一下:

        A: interactive_timeout:服务器关闭交互式连接前等待活动的秒数。交互式客户端定义为在mysql_real_connect()中使用CLIENT_INTERACTIVE选项的客户端。又见wait_timeout

        B: wait_timeout:服务器关闭非交互连接之前等待活动的秒数。在线程启动时,根据全局wait_timeout值或全局 interactive_timeout值初始化会话wait_timeout值,取决于客户端类型(由mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义),又见interactive_timeout

        总结:如此看来,两个变量是共同控制的,那么都必须对他们进行修改了 。继续深入这两个变量wait_timeout的取值范围是 1-2147483(Windows),1-31536000(linux),interactive_time取值随wait_timeout变动,它们的默认值都是28800

 

SHOW GLOBAL VARIABLES LIKE '%max';

找到:max_connections    335

 

三:找到%mysql_home%/my.ini,加入

wait_timeout=10
interactive_timeout=10

注:在my.ini中配置wait_timeout不起作用,则用如下方法

SET GLOBAL wait_timeout=120
SET GLOBAL interactive_timeout = 120
SHOW GLOBAL VARIABLES LIKE '%_timeout%'

如果重启mysql,则所有你刚才设置的GLOBAL数据都无效了.

然后重启mysql服务

 

四:检查并更改C3P0配置选项每60*60秒(1小时),检查连接池中的空闲连接

(1)idleConnectionTestPeriod(秒) 必须 < wait_timeout(秒)  ----------很重要的配置

(2)maxIdleTime必须(秒) > wait_timeout(秒)

(3)maxPoolSize必须 < max_connections

 

五:ok

可以测试一下你的连接,是不是解决了mysql8小时的问题

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值