linux平台
監控mysql執行的sql語句
為了做好配合開發做效能和功能測試,方便監控正在執行的sql語句,
可以在/etc/mysqld中添加如下:
log =/usr/local/mysql/var21005/mysql.log
就可以使用:
tail -f mysql.log www.111cn.net
來監控了
如果需要監控慢查詢可以添加如下內容:
log-slow-queries = /usr/local/mysql/var21005/slowquery.log
long_query_time = 1
windows平台
一windows平台下為例:
修改my.ini,在mysqld下添加log一行,
[mysqld]
log = "D:/tmp/mysql_log/mysql_log.sql"
然後,重新啟動mysql,就可以即時看到myql伺服器當前正在執行的語句了。
除了上面方法還可以使用慢日誌監控mysql執行狀態
啟用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– www.111cn.net
然後再重啟服務就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中寫日誌。