91在线视频_免费影院在线_欧美a级黄色大片_91精品视频在线看

巨靈鳥

電話   4000156919
當前位置:首頁 > 數據庫管理_ERP百科

Mysql 占用cpu資源高的分析

來源:巨靈鳥軟件  作者:進銷存軟件  發布:2014/5/31  瀏覽次數:5172

(Windows 2003 + IIS + PHP + MYSQL )近來 MySQL 服務進程 (mysqld-nt.exe) CPU 占用率總為 100% 高居不下。此主機有10個左右的 database, 分別給十個網站調用。據巨靈鳥DBA測試,導致 mysqld-nt.exe cpu 占用奇高的是網站A,一旦在 IIS 中將此網站停止服務,CPU 占用就降下來了。一啟用,則馬上上升。

MYSQL CPU 占用 100% 的解決過程

    今天早上仔細檢查了一下。目前此網站的七日平均日 IP 為2000,PageView 為 3萬左右。網站A 用的 database 目前有39個表,記錄數 60.1萬條,占空間 45MB。按這個數據,MySQL 不可能占用這么高的資源。

于是在服務器上運行命令,將 mysql 當前的環境變量輸出到文件 output.txt:

d:\web\mysql> mysqld.exe --help >output.txt

發現 tmp_table_size 的值是默認的 32M,于是修改 My.ini, 將 tmp_table_size 賦值到 200M:

d:\web\mysql> notepad c:\windows\my.ini [mysqld] tmp_table_size=200M

然后重啟 MySQL 服務。CPU 占用有輕微下降,以前的CPU 占用波形圖是 100% 一根直線,現在則在 97%~100%之間起伏。這表明調整 tmp_table_size 參數對 MYSQL 性能提升有改善作用。但問題還沒有完全解決。

于是進入 mysql 的 shell 命令行,調用 show processlist, 查看當前 mysql 使用頻繁的 sql 語句:

mysql> show processlist;


反復調用此命令(每秒刷兩次),發現網站 A 的兩個 SQL 語句經常在 process list 中出現,其語法如下:

SELECT t1.pid, t2.userid, t3.count, t1.date FROM _mydata AS t1 LEFT JOIN _myuser AS t3 ON t1.userid=t3.userid LEFT JOIN _mydata_body AS t2 ON t1.pid=t3.pid ORDER BY t1.pid LIMIT 0,15


調用 show columns 檢查這三個表的結構 :

mysql> show columns from _myuser; mysql> show columns from _mydata; mysql> show columns from _mydata_body;


終于發現了問題所在:_mydata 表,只根據 pid 建立了一個 primary key,但并沒有為 userid 建立索引。而在這個 SQL 語句的第一個 LEFT JOIN ON 子句中:

LEFT JOIN _myuser AS t3 ON t1.userid=t3.userid


_mydata 的 userid 被參與了條件比較運算。于是我為給 _mydata 表根據字段 userid 建立了一個索引:

mysql> ALTER TABLE `_mydata` ADD INDEX ( `userid` )


建立此索引之后,CPU 馬上降到了 80% 左右。看到找到了問題所在,于是檢查另一個反復出現在 show processlist 中的 sql 語句:

SELECT COUNT(*) FROM _mydata AS t1, _mydata_key AS t2 WHERE t1.pid=t2.pid and t2.keywords = '孔雀'


經檢查 _mydata_key 表的結構,發現它只為 pid 建了了 primary key, 沒有為 keywords 建立 index。_mydata_key 目前有 33 萬條記錄,在沒有索引的情況下對33萬條記錄進行文本檢索匹配,不耗費大量的 cpu 時間才怪。看來就是針對這個表的檢索出問題了。于是同樣為 _mydata_key 表根據字段 keywords 加上索引:

mysql> ALTER TABLE `_mydata_key` ADD INDEX ( `keywords` )


建立此索引之后,CPU立刻降了下來,在 50%~70%之間震蕩。

再次調用 show prosslist,網站A 的sql 調用就很少出現在結果列表中了。但發現此主機運行了幾個 Discuz 的論壇程序, Discuz論壇的好幾個表也存在著這個問題。于是順手一并解決,cpu占用再次降下來了。

至此,問題解決。

----------------------------------------------------------------------------------------

解決 MYSQL CPU 占用 100% 的經驗總結

1. 增加 tmp_table_size 值。mysql 的配置文件中,tmp_table_size 的默認大小是 32M。如果一張臨時表超出該大小,MySQL產生一個 The table tbl_name is full 形式的錯誤,如果你做很多高級 GROUP BY 查詢,增加 tmp_table_size 值。 這是 mysql 官方關于此選項的解釋:

tmp_table_size

This variable determines the maximum size for a temporary table in memory. If the table becomes too large, a MYISAM table is created on disk. Try to avoid temporary tables by optimizing the queries where possible, but where this is not possible, try to ensure temporary tables are always stored in memory. Watching the processlist for queries with temporary tables that take too long to resolve can give you an early warning that tmp_table_size needs to be upped. Be aware that memory is also allocated per-thread. An example where upping this worked for more was a server where I upped this from 32MB (the default) to 64MB with immediate effect. The quicker resolution of queries resulted in less threads being active at any one time, with all-round benefits for the server, and available memory.

2. 對 WHERE, JOIN, MAX(), MIN(), ORDER BY 等子句中的條件判斷中用到的字段,應該根據其建立索引 INDEX。

索引被用來快速找出在一個列上用一特定值的行。沒有索引,MySQL不得不首先以第一條記錄開始并然后讀完整個表直到它找出相關的行。表越大,花費時間越多。如果表對于查詢的列有一個索引,MySQL能快速到達一個位置去搜尋到數據文件的中間,沒有必要考慮所有數據。如果一個表有1000行,這比順序讀取至少快100倍。所有的MySQL索引(PRIMARY、UNIQUE和INDEX)在B樹中存儲。

根據 mysql 的開發文檔:

索引 index 用于:

o 快速找出匹配一個WHERE子句的行
   o 當執行聯結(JOIN)時,從其他表檢索行。
   o 對特定的索引列找出MAX()或MIN()值
   o 如果排序或分組在一個可用鍵的最左面前綴上進行(例如,ORDER BY key_part_1,key_part_2),排序或分組一個表。如果所有鍵值部分跟隨DESC,鍵以倒序被讀取。
   o 在一些情況中,一個查詢能被優化來檢索值,不用咨詢數據文件。如果對某些表的所有使用的列是數字型的并且構成某些鍵的最左面前綴,為了更快,值可以從索引樹被檢索出來。
假定你發出下列SELECT語句:

mysql> SELECT * FROM tbl_name WHERE col1=val1 AND col2=val2;

如果一個多列索引存在于col1和col2上,適當的行可以直接被取出。如果分開的單行列索引存在于col1和col2上,優化器試圖通過決定哪個索引將找到更少的行并來找出更具限制性的索引并且使用該索引取行。

開發人員做 SQL 數據表設計的時候,一定要通盤考慮清楚。

來源:巨靈鳥 歡迎分享本文

上一個文章:什么是MySQL

下一個文章:如何將MSSQL2005轉換成SQL2000

  • 點擊這里給我發消息
  • 點擊這里給我發消息
91在线视频_免费影院在线_欧美a级黄色大片_91精品视频在线看

    9000px;">

      精品国产乱码久久| 91精品国产色综合久久不卡蜜臀| 色婷婷综合中文久久一本| 51午夜精品国产| 国产精品国产三级国产有无不卡| 99久久精品免费看| 日韩丝袜情趣美女图片| 日韩专区中文字幕一区二区| www.66久久| 国产亚洲美州欧州综合国| 日韩av不卡一区二区| 成人不卡免费av| 中文字幕一区免费在线观看| 国产精品资源网| 国产农村妇女毛片精品久久麻豆 | 国产精品毛片大码女人| 久久99久久99| 国产欧美日韩卡一| 北岛玲一区二区三区四区| 精品女同一区二区| 国内精品自线一区二区三区视频| 国内精品国产成人国产三级粉色| 国产91清纯白嫩初高中在线观看 | 亚洲精品高清在线| 欧美天堂亚洲电影院在线播放| 欧美伊人久久大香线蕉综合69| 欧美精品v国产精品v日韩精品| 欧美成人三级电影在线| 国产美女精品在线| 亚洲男人都懂的| 日韩欧美一级片| 99国产精品久久久久久久久久| 91超碰这里只有精品国产| 美女高潮久久久| 亚洲国产精品二十页| gogogo免费视频观看亚洲一| 香蕉成人啪国产精品视频综合网| 国产精品影视天天线| 亚洲丝袜精品丝袜在线| 欧美sm极限捆绑bd| 欧美丝袜丝交足nylons图片| 国产乱妇无码大片在线观看| 亚洲成人激情综合网| 亚洲国产精品传媒在线观看| 欧美亚州韩日在线看免费版国语版| 精品成人a区在线观看| 欧洲生活片亚洲生活在线观看| 国产拍欧美日韩视频二区| 欧美在线free| aaa亚洲精品一二三区| 国产精品一区二区在线观看不卡 | 欧美日韩激情一区二区三区| 国产乱子伦视频一区二区三区| 日韩西西人体444www| 国产91色综合久久免费分享| 日本中文字幕一区二区视频 | 日韩欧美二区三区| 欧美日韩免费不卡视频一区二区三区| 亚洲欧洲日本在线| 日韩一区二区三区av| 欧美日韩不卡一区二区| 色妹子一区二区| 色婷婷久久综合| 91久久人澡人人添人人爽欧美| 午夜天堂影视香蕉久久| 亚洲青青青在线视频| 中文字幕一区二区三区乱码在线 | 麻豆国产精品视频| 青青草精品视频| 午夜欧美在线一二页| 性欧美疯狂xxxxbbbb| 视频一区免费在线观看| 三级欧美韩日大片在线看| 视频在线观看国产精品| 久久精品国产一区二区| 国产一区二区三区四区在线观看 | 蜜桃av一区二区| 极品少妇一区二区三区精品视频| 26uuu亚洲综合色| 欧美第一区第二区| 国产三区在线成人av| 国产精品黄色在线观看| 香蕉影视欧美成人| 国产一级精品在线| 欧洲一区二区av| 精品国产91乱码一区二区三区 | 97se狠狠狠综合亚洲狠狠| 91电影在线观看| 欧美精品一区二区三区很污很色的| 日本精品一区二区三区高清| 欧美一区二区在线免费播放| 久久精品免费在线观看| 亚洲黄色免费网站| 国产一区二区三区四区五区美女| 麻豆久久一区二区| 日本高清不卡视频| 欧美r级电影在线观看| 亚洲日本va午夜在线影院| 国精产品一区一区三区mba桃花| 性欧美疯狂xxxxbbbb| 国产剧情一区在线| 欧美日本在线看| 一区二区三区色| 不卡一二三区首页| 国产精品午夜久久| 激情欧美日韩一区二区| 在线亚洲精品福利网址导航| 国产区在线观看成人精品| 久久99精品久久久| 欧美一区二区福利视频| 丝袜亚洲另类欧美| 91久久国产综合久久| 亚洲美女在线一区| 91日韩一区二区三区| 国产精品色眯眯| 成人午夜电影网站| 国产精品欧美久久久久无广告| 国产精品久久久久久久久免费樱桃| 中文字幕不卡的av| 国产精品99久久久久久久女警| 成人精品国产免费网站| 国产精品午夜春色av| 97久久久精品综合88久久| 亚洲天堂精品在线观看| 色综合久久中文字幕| 亚洲大片一区二区三区| 正在播放亚洲一区| 秋霞影院一区二区| 久久九九国产精品| 一本一道波多野结衣一区二区| 日韩欧美在线1卡| 精品午夜久久福利影院| 精品免费国产二区三区| 国内精品第一页| 一区在线观看视频| 欧美挠脚心视频网站| 国产一区二区不卡在线| 有码一区二区三区| 欧美一区二区三区免费视频 | 香蕉久久一区二区不卡无毒影院| 美女网站一区二区| 久久午夜老司机| 在线看国产一区二区| 国产一区在线看| 亚洲成国产人片在线观看| 国产日产欧美一区二区视频| 欧美在线一二三四区| 成人中文字幕电影| 久久国产福利国产秒拍| 午夜欧美在线一二页| 国产精品午夜免费| 精品国产sm最大网站免费看| 欧美日韩中文一区| 在线看日本不卡| 色就色 综合激情| 成熟亚洲日本毛茸茸凸凹| 久久电影国产免费久久电影| 亚洲成人免费看| 亚洲成人手机在线| 亚洲一区中文在线| 亚洲精品中文字幕乱码三区| 国产精品久久久久久亚洲伦| 久久综合色天天久久综合图片| 国产一区在线精品| 亚洲综合色在线| 亚洲国产精品尤物yw在线观看| 欧美影院一区二区| 在线精品视频小说1| 欧美影视一区二区三区| 欧美日韩一级二级三级| 欧美日韩你懂得| 日韩一级完整毛片| 精品动漫一区二区三区在线观看| www.综合网.com| 色综合久久88色综合天天免费| 亚洲高清免费在线| 亚洲国产欧美在线| 久久超碰97人人做人人爱| 黄页视频在线91| 91蝌蚪porny| 日韩一区二区三区免费观看| 久久精品视频免费| 亚洲综合一区在线| 麻豆精品国产传媒mv男同| 成人亚洲一区二区一| 精品视频色一区| 国产欧美一区在线| 亚洲专区一二三| 国产一区二区三区在线观看精品| 亚洲高清免费观看高清完整版在线观看| 日韩视频免费观看高清完整版在线观看 | 久久蜜桃一区二区| 久久精品夜色噜噜亚洲a∨| 午夜精品视频在线观看| 欧美a级理论片| 在线免费观看日韩欧美| 亚洲精品一区二区精华| 亚洲国产精品久久艾草纯爱| 国产成人午夜99999| 欧美剧在线免费观看网站 |