您好,登錄后才能下訂單哦!
作者:盧飛,數(shù)據(jù)庫技術專家,Oracle ACE-A,Go語言愛好者
盧飛是老葉在搜狐暢游期間的同事,工作和學習能力都很強
操作系統(tǒng)及MySQL數(shù)據(jù)庫的實時性能狀態(tài)數(shù)據(jù)尤為重要,特別是在有性能抖動的時候,這些實時的性能數(shù)據(jù)可以快速幫助你定位系統(tǒng)或MySQL數(shù)據(jù)庫的性能瓶頸,就像你在Linux系統(tǒng)上使用「top,sar,iostat」等命令工具一樣,可以立刻定位OS的性能瓶頸是在IO還是CPU上,所以收集/展示這些性能數(shù)據(jù)就更為重要,那都有哪些重要的實時性能狀態(tài)指標可以反應出系統(tǒng)和MySQL數(shù)據(jù)庫的性能負載呢?
目前在Linux跑MySQL是大多數(shù)互聯(lián)網(wǎng)公司的標配,以上圖片的性能數(shù)據(jù)指標項是我認為在Linux,MySQL,InnoDB中較為重要的實時狀態(tài)數(shù)據(jù),然而在以上圖片Doing一欄其實更為重要,之所以把它叫做Doing,是因為「processlist,engine innodb status,locks」等指標項才真正反映了MySQL此時正在做什么。
我們來對標Oracle數(shù)據(jù)庫看一下,在Oracle數(shù)據(jù)庫中提供了「AWR,ASH,SQL Monitor」等眾多診斷工具,可以一眼望穿數(shù)據(jù)庫正在做什么,甚至都可以知道在過去30天內(nèi)任何一個時間區(qū)間的性能負載和當時數(shù)據(jù)庫正在做什么。
在MySQL中雖然有像「zabbix,PMM」等優(yōu)秀的監(jiān)控工具,但它們只能反映數(shù)據(jù)庫歷史的一些性能數(shù)據(jù)曲線,例如,TPS高了,臨時表使用多了,有InnoDB Deadlocks,但對于MySQL當時的Doing,我只能說不夠直接。如果你在現(xiàn)場,你可以抓到MySQL正在做什么,但是,你總有不在現(xiàn)場的時候,如果問你昨天晚上數(shù)據(jù)庫的性能抖動是什么原因?怎樣快速重現(xiàn)現(xiàn)場找到引起抖動的原因呢?
golang語言開發(fā)
可收集Linux、MySQL相關性能數(shù)據(jù)
可本地或遠程收集,可多臺
提供類似Linux top的mytop的功能
基于并發(fā)生成Doing日志,還原現(xiàn)場
可記錄到日志文件
遠程收集系統(tǒng)信息是通過ssh(需提供用戶名和密碼)的方式連接到遠程服務器上收集,收集的方法都是通過讀取Linux的proc下的等meminfo,diskstats,uptime,net,vmstat ,cpuinfo ,loadavg等文件,這和pmm,zabbix收集方式一致。
遠程收集MySQL信息是通過 MySQL tcp連接到MySQL數(shù)據(jù)庫上收集,只需要授予連接用戶PROCESS、SELECT權限即可。
系統(tǒng)信息和MySQL信息的收集可以分離,如果只想收集系統(tǒng)信息,只需要提供系統(tǒng)用戶名密碼即可,如果只收集MySQL可以只提供MySQL連接信息,如果是rds用戶,可以使用-rds參數(shù),在使用mytop時會自動忽略系統(tǒng)信息的收集。
https://github.com/dblucyne/dodba_tools
Download:
wget https://raw.githubusercontent.com/dblucyne/dodba_tools/master/doDBA --no-check-certificate
wget https://raw.githubusercontent.com/dblucyne/dodba_tools/master/doDBA.conf --no-check-certificate
chmod +x doDBA
下載下來就可以直接使用,不依賴于任何環(huán)境。
使用幫助:
./doDBA -help
-c string
configuration file. (default "doDBA.conf")
-h string
Connect to host/IP.
-sys
Print system info.
-myall
Print system and mysql info.
-mysql
Print mysql info.
-innodb
Print innodb info.
-mytop
Print mysql prcesslist info , like top.
-i duration
refresh interval in seconds. (default 1s)
-t int
doing on Threads_running. (default 50)
-rds
Ignore system info.
-log
Print to file by day.
-nocolor
Print to nocolor.
10.1.x.x1
10.1.x.x2
Shell
cat ip.txt | while read ip;
do
echo $ip;
./doDBA -h=$ip -mysql -log </dev/null &
done
使用【-t】參數(shù)可以基于Threads_running的數(shù)量設置閾值,設置后可記錄「processlist,engine innodb status」信息到dodba.log日志中,--重現(xiàn)現(xiàn)場。
./doDBA -h=10.1.x.xx -myall -t=3
如果你對golang感興趣,如果你對doDBA tools有問題或者建議,掃描二維碼,可聯(lián)系作者。
微信掃一掃
關注該公眾號
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。