<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

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲精品乱码久久久久久中文字幕| 在线观看H网址免费入口| 好男人看视频免费2019中文| 亚洲嫩草影院久久精品| 一个人看的www免费视频在线观看| 亚洲人成影院在线观看| 四虎精品成人免费视频| 国产性爱在线观看亚洲黄色一级片| 日本中文字幕免费看| 亚洲中文字幕无码永久在线| 成在线人视频免费视频| 久久噜噜噜久久亚洲va久| 99视频在线免费看| 亚洲人成伊人成综合网久久| 免费观看男人免费桶女人视频| 亚洲av日韩av永久无码电影| 四虎影库久免费视频| 四虎精品免费永久免费视频| 国产啪亚洲国产精品无码| 精品国产一区二区三区免费| 97亚洲熟妇自偷自拍另类图片| 国产精品久久永久免费| 亚洲高清毛片一区二区| 亚洲精品国产综合久久一线| 两个人看www免费视频| 亚洲视频国产精品| 日韩精品视频免费观看| 91av免费在线视频| 亚洲资源在线观看| 处破痛哭A√18成年片免费| 一级做a爰片性色毛片免费网站 | 两个人看的www高清免费观看| 亚洲日韩区在线电影| 成年人在线免费看视频| 免费人成动漫在线播放r18 | 国产亚洲精aa成人网站| 99久久综合精品免费| 亚洲人成色777777精品| 亚洲午夜未满十八勿入网站2| 成人在线免费看片| 在线播放免费人成视频网站 |