国产一区二区三区在线看片_日本韩国黄色_国产福利视频在线_成人97在线观看免费高清

巨靈鳥

電話   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

  • 點擊這里給我發消息
  • 點擊這里給我發消息
国产一区二区三区在线看片_日本韩国黄色_国产福利视频在线_成人97在线观看免费高清

              久久久精品一区| 国内精品福利| 久久久福利视频| 亚洲美女免费视频| 国产精品午夜在线观看| 欧美激情久久久| 久久av在线| 亚洲综合色婷婷| 亚洲欧洲日韩女同| 激情国产一区| 国产亚洲欧美一区在线观看| 欧美日韩高清在线一区| 快she精品国产999| 久久久久久久网| 久久国产精品亚洲77777| 99精品国产在热久久婷婷| 伊人久久大香线| 国产日韩一区在线| 国产精品入口日韩视频大尺度| 欧美成人在线免费观看| 久久一区二区三区超碰国产精品| 亚洲欧美日韩一区二区在线| 日韩亚洲欧美在线观看| 亚洲精品免费在线| 亚洲福利在线观看| 亚洲第一页在线| 韩曰欧美视频免费观看| 国产精品自拍在线| 国产精品户外野外| 欧美午夜不卡影院在线观看完整版免费| 巨乳诱惑日韩免费av| 另类av一区二区| 另类综合日韩欧美亚洲| 久久亚洲国产精品日日av夜夜| 午夜一区二区三区在线观看| 亚洲男人的天堂在线aⅴ视频| 亚洲欧美欧美一区二区三区| 亚洲免费一区二区| 久久er精品视频| 久久国产乱子精品免费女| 久久精品国产清高在天天线| 久久午夜电影网| 久久综合狠狠综合久久综青草| 蜜臀av性久久久久蜜臀aⅴ四虎| 榴莲视频成人在线观看| 欧美精品videossex性护士| 欧美日韩一区二区在线观看| 国产精品一区免费视频| 国产噜噜噜噜噜久久久久久久久 | 国产精品v一区二区三区| 欧美黄色小视频| 欧美视频网址| 国产亚洲精品一区二区| 一区在线视频| 亚洲视频在线观看视频| 性色av一区二区怡红| 久久久国产成人精品| 欧美激情按摩在线| 国产精品久在线观看| 精品1区2区| 一区二区av| 欧美在线播放一区二区| 久久一本综合频道| 欧美午夜精品一区| 国产有码一区二区| 亚洲视频在线看| 久久午夜羞羞影院免费观看| 欧美视频中文在线看 | 国产午夜精品全部视频在线播放 | 久久精品欧美日韩精品| 欧美韩日一区二区| 国产午夜亚洲精品不卡| 亚洲美女在线国产| 理论片一区二区在线| 国产精品久久午夜夜伦鲁鲁| 亚洲国内在线| 久久精品视频在线看| 欧美视频你懂的| 亚洲欧洲精品一区二区三区| 午夜国产精品视频| 欧美三级在线播放| 亚洲成人在线网| 欧美在线免费播放| 国产精品毛片高清在线完整版| 亚洲激情视频在线观看| 久久久久国色av免费观看性色| 国产精品劲爆视频| 99re亚洲国产精品| 欧美精品久久99| 亚洲黄色免费| 欧美成人精品在线观看| 在线日本欧美| 麻豆成人在线| 亚洲国产精品成人久久综合一区| 欧美一区二区成人6969| 欧美日韩在线三级| 国产精品播放| 亚洲视频一二| 国产精品福利在线观看| 99综合在线| 欧美三区在线视频| 亚洲午夜激情免费视频| 欧美日韩在线三级| 亚洲视频一区二区在线观看| 欧美日韩三区| 亚洲网站在线| 国产欧美精品一区aⅴ影院| 午夜精品久久| 激情另类综合| 欧美 亚欧 日韩视频在线| 亚洲福利视频三区| 欧美日韩岛国| 亚洲网站在线| 国产亚洲福利社区一区| 久久久亚洲高清| 亚洲国产精品一区二区尤物区 | 狠狠色狠狠色综合日日91app| 久久国产88| 亚洲丁香婷深爱综合| 欧美黄色免费网站| 亚洲图片欧美日产| 国产精品伊人日日| 久久综合狠狠综合久久综青草| 在线观看欧美日韩| 欧美日韩免费一区| 久久精品91| 亚洲精品在线二区| 国产精品人人做人人爽| 欧美jjzz| 亚洲欧美日产图| 亚洲三级电影全部在线观看高清| 欧美香蕉大胸在线视频观看| 久久国产精品一区二区三区| 亚洲第一黄网| 国产精品久久久久久久久久久久久 | 欧美国产日韩在线| 欧美伊久线香蕉线新在线| 亚洲欧洲日本在线| 激情另类综合| 国产精品捆绑调教| 欧美福利专区| 欧美一区二区视频在线观看| 亚洲黄色高清| 国产日韩欧美精品在线| 欧美乱大交xxxxx| 小黄鸭精品aⅴ导航网站入口| 亚洲国产精品久久久久秋霞不卡| 国产精品久久久久9999| 欧美福利一区二区三区| 欧美一区二区三区四区高清| 亚洲免费成人av电影| 亚洲成色999久久网站| 国产欧美日韩专区发布| 国产精品拍天天在线| 欧美精品久久99久久在免费线| 久久精品在线观看| 亚洲欧美日韩综合aⅴ视频| 一级成人国产| 亚洲理伦在线| 亚洲人成人一区二区三区| 精品福利电影| 好看的日韩视频| 国产欧美日韩综合精品二区| 欧美日韩亚洲一区二区| 欧美另类极品videosbest最新版本 | 91久久久亚洲精品| 韩国免费一区| 激情欧美一区二区三区| 国内自拍一区| 国内成人自拍视频| 国际精品欧美精品| 红桃视频国产一区| 在线播放中文字幕一区| 亚洲第一区色| 亚洲人永久免费| av成人免费观看| 亚洲欧美激情视频在线观看一区二区三区| 亚洲每日更新| 亚洲伊人网站| 久久精品视频va| 欧美a级在线| 欧美国产日韩二区| 欧美伦理一区二区| 欧美午夜在线| 国产日韩在线看片| 在线观看国产一区二区| 亚洲精品在线看| 亚洲欧美不卡| 久久久噜噜噜久噜久久 | 亚洲国产精品999| 99精品国产高清一区二区| 午夜精品久久久99热福利| 久久精品国产免费| 欧美丰满高潮xxxx喷水动漫| 欧美日韩综合一区| 国产日韩欧美亚洲一区| 最新日韩在线视频| 亚洲综合色在线| 欧美成人精品在线观看| 国产欧美日韩91|