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

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

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

    少年阿賓

    那些青春的歲月

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      500 Posts :: 0 Stories :: 135 Comments :: 0 Trackbacks
    MySQL 的默認設置下,當一個連接的空閑時間超過8小時后,MySQL 就會斷開該連接,而 c3p0 連接池則以為該被斷開的連接依然有效。在這種情況下,如果客戶端代碼向 c3p0 連接池請求連接的話,連接池就會把已經失效的連接返回給客戶端,客戶端在使用該失效連接的時候即拋出異常。
    解決這個問題的辦法有三種:
    1. 增加 MySQL 的 wait_timeout 屬性的值。
    修改 /etc/mysql/my.cnf 文件,在 [mysqld] 節中設置:
    # Set a connection to wait 8 hours in idle status.
    wait_timeout 
    = 86400
    2. 減少連接池內連接的生存周期,使之小于上一項中所設置的 wait_timeout 的值。
    修改 c3p0 的配置文件,設置:
    # 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. 定期使用連接池內的連接,使得它們不會因為閑置超時而被 MySQL 斷開。
    修改 c3p0 的配置文件,設置:
    # 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 文件中的屬性設置轉換成為 applicationContext.xml 中 數據庫連接池 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 閱讀(752) 評論(0)  編輯  收藏 所屬分類: dbConnectPool

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲国产中文v高清在线观看| a级毛片在线免费| 国产精品视频免费一区二区| 亚洲视频小说图片| 69视频在线观看免费| 亚洲邪恶天堂影院在线观看| 国产激情免费视频在线观看| 亚洲AV日韩AV永久无码下载| 五月婷婷免费视频| 亚洲国产中文v高清在线观看| 亚洲1区2区3区精华液| 免费A级毛片在线播放不收费| 国产亚洲人成网站观看| 99re6在线精品免费观看| 亚洲精品高清国产一线久久| 玖玖在线免费视频| 亚洲国产高清在线精品一区| 成人性生交视频免费观看| 国产AⅤ无码专区亚洲AV| 日本道免费精品一区二区| 日木av无码专区亚洲av毛片| 很黄很色很刺激的视频免费| 亚洲AV无码资源在线观看| 亚洲成A人片77777国产| 中文字幕的电影免费网站| 日韩精品福利片午夜免费观着| 久久亚洲精品国产亚洲老地址| 成全高清视频免费观看| 日本一区二区三区在线视频观看免费 | 亚洲精品视频在线观看免费| 亚洲综合无码一区二区痴汉| heyzo亚洲精品日韩| 国产精品免费无遮挡无码永久视频 | 三上悠亚在线观看免费| 亚洲天堂男人天堂| 日本19禁啪啪无遮挡免费动图| 一级做a毛片免费视频| 亚洲综合激情九月婷婷| 免费又黄又爽的视频| 久久久久久国产精品免费免费男同| 亚洲国产成人乱码精品女人久久久不卡|