linux/windows平台監控mysql執行的sql語句

來源:互聯網
上載者:User

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中寫日誌。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.