mysql慢查詢日志對于跟蹤有問題的查詢非常有用,可以分析出當前程序里有很耗費資源的sql語句,那如何打開mysql的慢查詢日志記錄呢?
其實打開mysql的慢查詢日志很簡單,只需要在mysql的配置文件里(windows系統是my.ini,linux系統是my.cnf)的[mysqld]下面加上如下代碼:
log-slow-queries=/var/lib/mysql/slowquery.log
long_query_time=2
注:
log-slow-queries 設置把日志寫在那里,為空的時候,系統會給慢查詢日志賦予主機名,并被附加slow.log. /var/lib/mysql/slowquery.log為日志存放的文件的位置,一般這個目錄要有mysql的運行帳號的可寫權限,一般都將這個目錄設置為mysql的數據存放目錄
long_query_time=2中的2表示查詢超過兩秒才記錄.
如果設置了參數log-long-format,那么所有沒有使用索引的查詢也將被記錄。在文件my.cnf或my.ini中加入下面這一行可以記錄這些查詢
這是一個有用的日志。它對于性能的影響不大(假設所有查詢都很快),并且強調了那些最需要注意的查詢(丟失了索引或索引沒有得到最佳應用)
# Time: 070927 8:08:52
# User@Host: root[root] @ [192.168.0.20]
# Query_time: 372 Lock_time: 136 Rows_sent: 152 Rows_examined: 263630
select id, name from manager where id in (66,10135);
這是慢查詢日志中的一條,用了372秒,鎖了136秒,返回152行,一共查了263630行
如果日志內容很多,用眼睛一條一條去看會累死,mysql自帶了分析的工具,使用方法如下:
命令行下,進入mysql/bin目錄,輸入mysqldumpslow
主站蜘蛛池模板:
喀喇|
十堰市|
巍山|
民丰县|
视频|
景宁|
随州市|
建德市|
特克斯县|
彝良县|
若尔盖县|
文成县|
房产|
吉林市|
章丘市|
镶黄旗|
饶河县|
文安县|
高雄市|
九寨沟县|
元谋县|
永兴县|
湟中县|
高唐县|
邵东县|
新邵县|
普兰县|
安新县|
天水市|
沈阳市|
远安县|
蒙山县|
白玉县|
东莞市|
万州区|
都昌县|
江口县|
新疆|
汕头市|
交城县|
明溪县|