程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 根據mysql慢日志監控SQL語句執行效率

根據mysql慢日志監控SQL語句執行效率

編輯:關於MYSQL數據庫
根據mysql慢日志監控SQL語句執行效率

啟用MySQL的log-slow-queries(慢查詢記錄)。

在Linux環境下先要找到my.cnf文件(一般在/etc/mysql/),然後可能會發現該文件修改後無法保存,原因是你沒有相應的權限,可以從屬性中看到該文件的所有者是root,這時要先以root的身份打開它:

sudo nautilus /etc/mysql

接著再打開my.cnf文件然後找到[mysqld]標簽在下面加上:

log-slow-queries=/path/slow.log –慢日志保存路徑,該文件自己新建
long_query_time=2 –超過2秒的查詢
log-queries-not-using-indexes –記錄沒有使用索引的查詢

保存,關閉。然後如果重啟MySQL的話會碰到這樣的提示:world-writable config file ‘ etc my.cnf' is ignored

這時需要你再運行這個代碼:

chmod 644 /etc/my.cnf –644表示rw-r–r–

然後再重啟服務就OK了。

但是要注意的是:log-slow-queries=/path/slow.log為慢查詢日志存放的地方,而這個目錄要有MySQL的運行帳號的可寫權限,一般都將這個目錄設置為MySQL的數據存放目錄。

我是這麼做的:先用root用戶進到MySQL的數據存放目錄(一般是/var/lib/mysql),新建一個slow.log文件(root用戶能保證有權限新建,再運行chmod 644)。然後更改該文件的所有者和所在組:

chown mysql運行帳戶的名字(可以看同文件夾中其他文件的所有者和組)+小數點+組名(方法同用戶名) /path/slow.log

或者:

chown mysql運行帳戶的名字(可以看同文件夾中其他文件的所有者和組) /path/slow.log

chgrp 組名(方法同用戶名) /path/slow.log

這樣才能保證MySQL能往slow.log中寫日志。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved