mysql怎么設置監(jiān)控 MySQL 監(jiān)控

zabbix進程監(jiān)控mysql+,windosmysql如何配置?

1.

聶拉木網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、APP開發(fā)、成都響應式網(wǎng)站建設公司等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)2013年至今到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設就選創(chuàng)新互聯(lián)。

被監(jiān)控MySQL主機設置

2.

被監(jiān)控MySQL主機配置 mysql grant usage on *.* to 'zabbix'@'localhost' identified by 'zabbix'; mysql flush ...

3.

設置完帳戶之后在被監(jiān)控端新建/etc/zabbix/.my.cnf以提供Zabb...

4.

zabbix界面配置 在zabbix圖形界面添加MySQL主機(此處不做詳述) ...

如何監(jiān)控mysql表記錄變化

本期我們用 MySQL 提供的 DBUG 工具來研究 MySQL 的 SQL 處理流程。

起手先造個實例

這里得稍微改一下實例的啟動文件 start,將 CUSTOM_MYSQLD 改為 mysqld-debug:

重啟一下實例,加上 debug 參數(shù):

我們來做一兩個實驗,說明 DBUG 包的作用:

先設置一個簡單的調(diào)試規(guī)則,我們設置了兩個調(diào)試選項:

d:開啟各個調(diào)試點的輸出

O,/tmp/mysqld.trace:將調(diào)試結果輸出到指定文件

請點擊輸入圖片描述

然后我們創(chuàng)建了一張表,來看一下調(diào)試的輸出結果:

請點擊輸入圖片描述

可以看到 create table 的過程中,MySQL 的一些細節(jié)操作,比如分配內(nèi)存 alloc_root 等

這樣看還不夠直觀,我們增加一些信息:

請點擊輸入圖片描述

來看看效果:

請點擊輸入圖片描述

可以看到輸出變成了調(diào)用樹的形式,現(xiàn)在就可以分辨出 alloc_root 分配的內(nèi)存,是為了解析 SQL 時用的(mysql_parse)

我們再增加一些有用的信息:

請點擊輸入圖片描述

可以看到結果中增加了文件名和行號:

請點擊輸入圖片描述

現(xiàn)在我們可以在輸出中找一下統(tǒng)計表相關的信息:

請點擊輸入圖片描述

可以看到 MySQL 在這里非常機智,直接執(zhí)行了一個內(nèi)置的存儲過程來更新統(tǒng)計表。

沿著 que_eval_sql,可以找到其他類似的統(tǒng)計表,比如下面這些:

請點擊輸入圖片描述

請點擊輸入圖片描述

本次實驗中,我們借助了 MySQL 的 DBUG 包,來讓 MySQL 將處理過程暴露出來。MySQL 中類似的技術還有不少,比如 performance_schema,OPTIMIZER_TRACE 等等。

這些技術將 MySQL 的不同方向的信息暴露出來,方便大家理解其中機制。

如何監(jiān)控MySQL

首先介紹下 pt-stalk,它是 Percona-Toolkit 工具包中的一個工具,說起 PT 工具包大家都不陌生,平時常用的 pt-query-digest、 pt-online-schema-change 等工具都是出自于這個工具包,這里就不多介紹了。

pt-stalk 的主要功能是在出現(xiàn)問題時收集 OS 及 MySQL 的診斷信息,這其中包括:

1. OS 層面的 CPU、IO、內(nèi)存、磁盤、網(wǎng)絡等信息;

2. MySQL 層面的行鎖等待、會話連接、主從復制,狀態(tài)參數(shù)等信息。

而且 pt-stalk 是一個 Shell腳本,對于我這種看不懂 perl 的人來說比較友好,腳本里面的監(jiān)控邏輯與監(jiān)控命令也可以拿來參考,用于構建自己的監(jiān)控體系。

三、使用

接著我們來看下如何使用這個工具。

pt-stalk 通常以后臺服務形式監(jiān)控 MySQL 并等待觸發(fā)條件,當觸發(fā)條件時收集相關診斷數(shù)據(jù)。

觸發(fā)條件相關的參數(shù)有以下幾個:

function:

°?默認為 status,代表監(jiān)控 SHOW GLOBAL STATUS 的輸出;

°?也可以設置為 processlist,代表監(jiān)控 show processlist 的輸出;

variable:

°?默認為 Threads_running,代表 監(jiān)控參數(shù),根據(jù)上述監(jiān)控輸出指定具體的監(jiān)控項;

threshold:

°?默認為 25,代表 監(jiān)控閾值,監(jiān)控參數(shù)超過閾值,則滿足觸發(fā)條件;

°?監(jiān)控參數(shù)的值非數(shù)字時,需要配合 match 參數(shù)一起使用,如 processlist 的 state 列;

cycles:

°?默認為 5,表示連續(xù)觀察到五次滿足觸發(fā)條件時,才觸發(fā)收集;

連接參數(shù):host、password、port、socket。

其他一些重要參數(shù):

iterations:該參數(shù)指定 pt-stalk 在觸發(fā)收集幾次后退出,默認會一直運行。

run-time:觸發(fā)收集后,該參數(shù)指定收集多長時間的數(shù)據(jù),默認 30 秒。

sleep:該參數(shù)指定在觸發(fā)收集后,sleep 多久后繼續(xù)監(jiān)控,默認 300 秒。

interval:指定狀態(tài)參數(shù)的檢查頻率,判斷是否需要觸發(fā)收集,默認 1 秒。

dest:監(jiān)控數(shù)據(jù)存放路徑,默認為 /var/lib/pt-stalk。

retention-time :監(jiān)控數(shù)據(jù)保留時長,默認 30 天。

daemonize:以后臺服務運行,默認不開啟。

log:后臺運行日志,默認為 /var/log/pt-stalk.log。

collect:觸發(fā)發(fā)生時收集診斷數(shù)據(jù),默認開啟。

°?collect-gdb:收集 GDB 堆棧跟蹤,需要 gdb 工具。

°?collect-strace:收集跟蹤數(shù)據(jù),需要 strace 工具。

°?collect-tcpdump:收集 tcpdump 數(shù)據(jù),需要 tcpdump 工具。

如何監(jiān)控MySQL性能

一,獲取mysql用戶下的進程總數(shù)

ps -ef | awk '{print $1}' | grep "mysql" | grep -v "grep" | wc-1

二,主機性能狀態(tài)

# uptime

[root@ ~]# uptime

13:05:52 up 53 days, 52 min, 1 user, load average: 0.00, 0.00, 0.00

三,CPU使用率

# top

# vmstat

四,磁盤IO量

# vmstat 或 # iostat

五,swap進出量[內(nèi)存]

# free

六,數(shù)據(jù)庫性能狀態(tài)

(1)QPS(每秒Query量)

QPS = Questions(or Queries) / seconds

mysql show /*50000 global */ status like 'Question';

(2)TPS(每秒事務量)

TPS = (Com_commit + Com_rollback) / seconds

mysql show status like 'Com_commit';

mysql show status like 'Com_rollback';

(3)key Buffer 命中率

key_buffer_read_hits = (1-key_reads / key_read_requests) * 100%

key_buffer_write_hits = (1-key_writes / key_write_requests) * 100%

mysql show status like 'Key%';

(4)InnoDB Buffer命中率

innodb_buffer_read_hits = (1 - innodb_buffer_pool_reads / innodb_buffer_pool_read_requests) * 100%

mysql show status like 'innodb_buffer_pool_read%';

(5)Query Cache命中率

Query_cache_hits = (Qcahce_hits / (Qcache_hits + Qcache_inserts )) * 100%;

mysql show status like 'Qcache%';

(6)Table Cache狀態(tài)量

mysql show status like 'open%';

(7)Thread Cache 命中率

Thread_cache_hits = (1 - Threads_created / connections ) * 100%

mysql show status like 'Thread%';

mysql show status like 'Connections';

(8)鎖定狀態(tài)

mysql show status like '%lock%';

(9)復制延時量

mysql show slave status

(10) Tmp Table 狀況(臨時表狀況)

mysql show status like 'Create_tmp%';

(11) Binlog Cache 使用狀況

mysql show status like 'Binlog_cache%';

(12) Innodb_log_waits 量

mysql show status like 'innodb_log_waits';

當然你也可以使用一下開源監(jiān)控軟件進行監(jiān)控

一,RRDTool

二,Nagios

三,MRTG

四,Cacti

如何使cacti監(jiān)控mysql服務器

cacti監(jiān)控mysql數(shù)據(jù)庫的方法

環(huán)境:

Cactiez或者cacti主機:192.168.12.5

被監(jiān)控mysql數(shù)據(jù)庫主機:192.168.5.231

1. 安裝監(jiān)控插件

cd /opt

tar -xzvf mysql-cacti-templates-1.1.2.tar.gz

cp /opt/mysql-cacti-templates-1.1.2/ss_get_mysql_stats.php /var/www/html/scripts/

其實里面我們要監(jiān)控mysql用到的是:acti_host_template_x_db_server_ht_0.8.6i.xml和mysql_definitions.pl

其他則是監(jiān)控Apache和Nginx的,接下來我們會介紹到,這里不再詳細的講了。

chown -R apache.apache /var/www/html/scripts

chmod -R 755 /var/www/html/scripts

使用 http 訪問 cacti主機 導入

/opt/mysql-cacti-templates-1.1.2/cacti_host_template_x_db_server_ht_0.8.6i.xml

默認CactiEZ 和Cacti別是 admin admin

控制臺 - 導入導出 - 模板導入 - 瀏覽

選中 cacti_host_template_x_db_server_ht_0.8.6i.xml

保存

2. 配置cacti的mysql插件

修改 ss_get_mysql_stats.php

vi /var/www/html/scripts/ss_get_mysql_stats.php

$mysql_user = 'cacti';

$mysql_pass = 'cacti';

$cache_dir = "/tmp/cacti/cache/";

這個賬戶和密碼是 被監(jiān)控端主機 給 Cacti主機 授權的 賬戶和密碼

Cacti需要這個賬戶和密碼去連接 被監(jiān)控機 查詢狀態(tài)

mkdir -p /tmp/cacti/cache

chown -R apache.apache /tmp/cacti

chmod -R 755 /tmp/cacti

設置 cacti 緩存目錄在 /tmp/cacti/cache/ 并給予權限

3. 配置被監(jiān)控端(192.168.5.231)的mysql 給 cacti 主機授權

mysql -uroot -p

grant process,super on *.* to 'cacti'@'192.168.12.5' identified by 'cacti';

exit

grant process,super on *.* to '賬戶'@'Cacti主機IP地址' identified by '密碼';此命令意義

只允許IP為 192.168.12.5 的主機 以賬戶 cacti 密碼 cacti 去訪問 本機數(shù)據(jù)

4. 在Cacti主機上(192.168.12.5) 監(jiān)控Mysql

4.1 為主機添加mysql模塊

控制臺 - 管理 - 設備 - 選中之前創(chuàng)建好的主機

然后移到最下面的 添加圖形模版 選中 Mysql相關模塊 然后保存

4.2 為mysql模塊創(chuàng)建圖形

控制臺 - 創(chuàng)建 - 創(chuàng)建圖形 - 選中該主機 - 選中mysql模塊 - 創(chuàng)建

4.3 插件mysql性能數(shù)據(jù)

監(jiān)視器 - 選中該主機 - 查閱對應的mysql

完畢

-----一些數(shù)據(jù)庫操作語句

mysqld_safe --user=mysql

mysql -uroot -p

mysql -uroot -proot

grant ALL PRIVILEGES ON *.* to ‘root’@"%" identified by "root" WITH GRANT OPTION;

exit

grant select,insert,update,delete on cacti.* to ‘cacti’@”*”identified by "cacti";

exit

grant process,super on *.* to 'cacti'@'%' identified by 'cacti';

grant all privileges on cacti.* to ‘cacti’@"%" identified by "cacti";

客戶端開啟Cacti訪問本機mysql的權限

grant process,super on *.* to 'cacti'@'192.168.12.5' identified by 'cacti';

grant process,super on *.* to 'cacti'@'192.168.5.231' identified by 'cacti';

= = = = =

mysql -ucacti -pcacti -h 192.168.5.231

如何實現(xiàn)MySQL性能監(jiān)控

命令: show processlist;

如果是root帳號,你能看到所有用戶的當前連接。如果是其它普通帳號,只能看到自己占用的連接。

show processlist;只列出前100條,如果想全列出請使用show full processlist;

mysql show processlist;

命令: show status;

命令:show status like '%下面變量%';

Aborted_clients 由于客戶沒有正確關閉連接已經(jīng)死掉,已經(jīng)放棄的連接數(shù)量。

當前文章:mysql怎么設置監(jiān)控 MySQL 監(jiān)控
URL分享:http://muchs.cn/article26/doocccg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化、網(wǎng)頁設計公司、企業(yè)建站、響應式網(wǎng)站、標簽優(yōu)化、手機網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設