在路上

          路上有驚慌,路上有理想

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            28 Posts :: 1 Stories :: 10 Comments :: 0 Trackbacks
          1.注意auto_increment
          mysql5.0在高并發(fā)下(每天近2億)插入單表數(shù)據(jù)出現(xiàn)了死鎖(偶現(xiàn)),查了下相關(guān)文檔,發(fā)現(xiàn)是因?yàn)椴捎昧薬uto-increment的主鍵帶來的問題,造成Table級的死鎖。
          原因:
          對于auto_increment字段,innodb會在內(nèi)存里保存一個(gè)計(jì)數(shù)器用來記錄auto_increment的值,當(dāng)插入一個(gè)新行數(shù)據(jù)時(shí),就會用一個(gè)表鎖來鎖住這個(gè)計(jì)數(shù)器,所以會造成Table級的死鎖。

          在Mysql5.1服務(wù)器配置多了一個(gè)參數(shù)innodb_autoinc_lock_mode,可以設(shè)置不同的值避免這個(gè)問題。比如設(shè)為1
          innodb_autoinc_lock_mode = 0
          (“traditional” lock mode)
          innodb_autoinc_lock_mode = 1 (“consecutive” lock mode) Mysql5.1默認(rèn)
          innodb_autoinc_lock_mode = 2 (“interleaved” lock mode)

          2.注意數(shù)據(jù)庫連接

          應(yīng)用中偶現(xiàn)性錯(cuò)誤:

          Last packet sent to the server was 8202 ms ago.; nested exception is com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

          連接池中的connection無法連接到數(shù)據(jù)庫,原因是池中的空閑conn連接db超時(shí),而c3p0 pool本身不知道。
          查了下Mysql5.0文檔,默認(rèn)的等待時(shí)間是8小時(shí)——show global variables like 'wait_timeout'
          但是該服務(wù)器的時(shí)間又不太合理。
          還是覺得在jdbc pool上做調(diào)整,比如在jdbc.url加入一個(gè)參數(shù)autoReconnect=true。可以解決。

          3.重視jdbc連接池配置
            高并發(fā)下,4個(gè)連接池,每個(gè)100個(gè)最大連接。高峰期出行can not get a connection的錯(cuò)誤。詢問過DBA,mysql數(shù)據(jù)庫高峰期最大連接近300。
            理論上連接池還是夠的。但仍然爆掉。推測原因可能出在DBCP連接池有些連接使用后一直被占著,沒有釋放回連接池。
            據(jù)此,修改DBCP配置,加入2個(gè)參數(shù):
            removeAbandoned=true
           
          removeAbandonedTimeout==200
           
            問題不再出現(xiàn)。
          4.字符集文件
          mysql 數(shù)據(jù)庫目錄下面有個(gè)文件db.opt ,記錄了db的字符集。如果你是通過alter databases(schema) 命令更改的數(shù)據(jù)庫默認(rèn)屬性,那么現(xiàn)有的表的默認(rèn)字符集和排序規(guī)則不受影響。新建的表即使不指定字符集,仍采用數(shù)據(jù)庫的字符集。

           

          posted on 2010-12-09 12:56 阮步兵 閱讀(1662) 評論(2)  編輯  收藏 所屬分類: MySQL

          Feedback

          # Juicy Couture 2010-12-09 16:41 Juicy Couture
          嗯 有些該注意的地方 都注意了  回復(fù)  更多評論
            

          # re: mysql學(xué)習(xí)筆記(2) 2010-12-10 10:05 mashiguang
          收藏了,謝謝  回復(fù)  更多評論
            


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


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 郸城县| 威信县| 台东市| 合山市| 吴旗县| 江都市| 西华县| 聊城市| 兴和县| 衡水市| 承德市| 桂林市| 日照市| 交城县| 柳林县| 盐山县| 竹溪县| 天峻县| 营口市| 巴南区| 盘锦市| 东明县| 新兴县| 紫云| 故城县| 邵武市| 金堂县| 拜城县| 车险| 元朗区| 乐亭县| 保亭| 类乌齐县| 疏附县| 岑巩县| 翁源县| 南昌市| 五峰| 资中县| 洮南市| 新疆|