<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    少年阿賓

    那些青春的歲月

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      500 Posts :: 0 Stories :: 135 Comments :: 0 Trackbacks
    MySQL 的默認(rèn)設(shè)置下,當(dāng)一個連接的空閑時間超過8小時后,MySQL 就會斷開該連接,而 c3p0 連接池則以為該被斷開的連接依然有效。在這種情況下,如果客戶端代碼向 c3p0 連接池請求連接的話,連接池就會把已經(jīng)失效的連接返回給客戶端,客戶端在使用該失效連接的時候即拋出異常。
    解決這個問題的辦法有三種:
    1. 增加 MySQL 的 wait_timeout 屬性的值。
    修改 /etc/mysql/my.cnf 文件,在 [mysqld] 節(jié)中設(shè)置:
    # Set a connection to wait 8 hours in idle status.
    wait_timeout 
    = 86400
    2. 減少連接池內(nèi)連接的生存周期,使之小于上一項中所設(shè)置的 wait_timeout 的值。
    修改 c3p0 的配置文件,設(shè)置:
    # How long to keep unused connections around(in seconds)
    # Note: MySQL times out idle connections after 
    8 hours(28,800 seconds)
    # so ensure this value is below MySQL idle timeout
    cpool.maxIdleTime
    =25200
    在 Spring 的配置文件中:
    <bean id="dataSource"
        class
    ="com.mchange.v2.c3p0.ComboPooledDataSource">
        
    <property name="maxIdleTime" value="${cpool.maxIdleTime}" />
        
    <!-- other properties -->
    </bean>
    3. 定期使用連接池內(nèi)的連接,使得它們不會因為閑置超時而被 MySQL 斷開。
    修改 c3p0 的配置文件,設(shè)置:
    # Prevent MySQL raise exception after a long idle time
    cpool.preferredTestQuery
    ='SELECT 1'
    cpool.idleConnectionTestPeriod
    =18000
    cpool.testConnectionOnCheckout
    =true
    修改 Spring 的配置文件:
    <bean id="dataSource"
        class
    ="com.mchange.v2.c3p0.ComboPooledDataSource">
        
    <property name="preferredTestQuery"
            value
    ="${cpool.preferredTestQuery}" />
        
    <property name="idleConnectionTestPeriod"
            value
    ="${cpool.idleConnectionTestPeriod}" />
        
    <property name="testConnectionOnCheckout"
            value
    ="${cpool.testConnectionOnCheckout}" />
        
    <!-- other properties -->
    </bean>

    附:以下 awk 腳本可以用以將 c3p0.properties 文件中的屬性設(shè)置轉(zhuǎn)換成為 applicationContext.xml 中 數(shù)據(jù)庫連接池 DataSource 所需的 XML 元素形式。
    #!/bin/awk

    BEGIN {
        FS
    ="=";
    }
    {
        
    if (NF == 2) {
            
    if ((x=index($1, ".")) > 0) {
                property_name 
    = substr($1, x+1, length($1));
            } 
    else {
                property_name 
    = $1;
            }
            printf
    ("<property name="%s" value="${%s}"/> ", property_name, $1);
        }
    }
    posted on 2014-12-15 20:15 abin 閱讀(745) 評論(0)  編輯  收藏 所屬分類: dbConnectPool

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 日本免费网站观看| 亚洲码和欧洲码一码二码三码| 免费无遮挡无码视频网站| 免费一级毛片在线播放视频| 国产精品亚洲专区无码唯爱网| 亚洲乱码一区av春药高潮| 亚洲AV永久精品爱情岛论坛| 大胆亚洲人体视频| 成人性生交大片免费看午夜a| 午夜视频在线免费观看| japanese色国产在线看免费| 国产精品亚洲专区无码WEB| 久久久久亚洲国产| 亚洲天堂一区二区三区| 亚洲三级电影网址| 国产亚洲一区二区精品| 最新精品亚洲成a人在线观看| 国产zzjjzzjj视频全免费| 午夜私人影院免费体验区| 久久综合AV免费观看| 99爱在线精品免费观看| 最近中文字幕无免费| 国内精品99亚洲免费高清| 国产黄在线播放免费观看| 在线播放国产不卡免费视频| 国产亚洲精品美女久久久久| 亚洲成a人片在线观看天堂无码 | 美女尿口扒开图片免费| 亚洲成av人无码亚洲成av人| 美女视频黄免费亚洲| 亚洲精品中文字幕| 亚洲风情亚Aⅴ在线发布| 亚洲av成本人无码网站| 婷婷亚洲综合五月天小说在线| 亚洲AV色无码乱码在线观看| 亚洲乱码国产乱码精华| 亚洲国产精品无码第一区二区三区| 亚洲aⅴ天堂av天堂无码麻豆| 亚洲a∨无码精品色午夜| 看一级毛片免费观看视频| 亚洲av无码日韩av无码网站冲|