<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)一個(gè)連接的空閑時(shí)間超過8小時(shí)后,MySQL 就會(huì)斷開該連接,而 c3p0 連接池則以為該被斷開的連接依然有效。在這種情況下,如果客戶端代碼向 c3p0 連接池請(qǐng)求連接的話,連接池就會(huì)把已經(jīng)失效的連接返回給客戶端,客戶端在使用該失效連接的時(shí)候即拋出異常。
    解決這個(gè)問題的辦法有三種:
    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)連接的生存周期,使之小于上一項(xiàng)中所設(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)的連接,使得它們不會(huì)因?yàn)殚e置超時(shí)而被 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) 評(píng)論(0)  編輯  收藏 所屬分類: dbConnectPool

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


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 两个人看www免费视频| 国产成人亚洲精品91专区高清| youjizz亚洲| 亚洲人av高清无码| 美女的胸又黄又www网站免费| 亚洲免费一区二区| 国产精品99精品久久免费| 18禁美女黄网站色大片免费观看| 中文字幕无码不卡免费视频| 免费a级毛片永久免费| 亚洲色精品vr一区二区三区 | 日韩成人免费视频播放| 亚洲国产精品视频| 亚洲AV日韩精品久久久久| 2017亚洲男人天堂一| 四虎精品成人免费视频| 一区二区三区在线免费看| 性色av免费观看| 国产成人精品日本亚洲专区61| 亚洲美女中文字幕| 久久精品国产亚洲AV天海翼| 国产在线精品一区免费香蕉| aa级一级天堂片免费观看| 亚洲欧洲一区二区三区| 中文字幕亚洲精品| 含羞草国产亚洲精品岁国产精品| 精品久久久久久无码免费| 思思re热免费精品视频66| 日批日出水久久亚洲精品tv| 伊人久久综在合线亚洲2019| 亚洲AV无码精品国产成人| 久久这里只精品99re免费| 在线免费视频一区| 亚洲AV午夜成人影院老师机影院| 最新国产精品亚洲| a毛片免费全部播放完整成| 免费观看理论片毛片| 亚洲av无码成h人动漫无遮挡| 色九月亚洲综合网| **一级一级毛片免费观看| 亚洲国产成人影院播放|