mycheckpoint 是針對mysql的一個性能監控、指標採集的python寫成的工具。html
工做原理說明:python
mycheckpoint是一段腳本,經過將其設置爲crontab定時任務,每幾分鐘採集一次數據(受限於crontab只能是分鐘爲基本單位)存儲在本身的數據庫中,並能夠將採集的數據進行統計,以web頁面的形式展示出來。mysql
示例效果:web
詳細請參見:http://code.openark.org/forge/mycheckpointsql
使用步驟:數據庫
0. 下載:api
wget https://mycheckpoint.googlecode.com/files/mycheckpoint-231.tar.gzapp
1. 爲mycheckpoint建立數據庫 socket
CREATE DATABASE mycheckpoint;
2. 受權給當前登陸mysql的用戶工具
GRANT ALL PRIVILEGES ON mycheckpoint.* TO 'root'@'localhost' IDENTIFIED BY 'xxxx';
3. 建立mycheckpoint須要的數據庫表。
mycheckpoint --host=127.0.0.1 --port=3306 --user=root --password=xxxx --socket=/mysql/tmp/mysql.sock --database=mycheckpoint
進過這一個步驟以後,會在名爲:mycheckpoint數據庫中,生成如下數據表。
+------------------------------------+ | Tables_in_mycheckpoint | +------------------------------------+ | alert | | alert_condition | | alert_condition_query_view | | alert_email_message_items_view | | alert_pending | | alert_pending_html_view | | alert_pending_view | | alert_view | | charts_api | | custom_query | | custom_query_top_navigation_view | | custom_query_view | | html_components | | metadata | | numbers | | status_variables | | status_variables_aggregated_day | | status_variables_aggregated_hour | | sv_custom_chart_day | | sv_custom_chart_flattened_day | | sv_custom_chart_flattened_hour | | sv_custom_chart_flattened_sample | | sv_custom_chart_hour | | sv_custom_chart_sample | | sv_custom_html | | sv_custom_html_brief | | sv_day | | sv_diff | | sv_hour | | sv_latest | | sv_param_change | | sv_parameter_change_union | | sv_report_24_7 | | sv_report_24_7_minmax | | sv_report_chart_24_7 | | sv_report_chart_day | | sv_report_chart_day_labels | | sv_report_chart_day_timeseries | | sv_report_chart_hour | | sv_report_chart_hour_labels | | sv_report_chart_hour_timeseries | | sv_report_chart_sample | | sv_report_chart_sample_labels | | sv_report_chart_sample_timeseries | | sv_report_day | | sv_report_day_recent | | sv_report_day_recent_minmax | | sv_report_hour | | sv_report_hour_recent | | sv_report_hour_recent_minmax | | sv_report_html | | sv_report_html_24_7 | | sv_report_html_brief | | sv_report_human_day | | sv_report_human_hour | | sv_report_human_sample | | sv_report_sample | | sv_report_sample_recent | | sv_report_sample_recent_aggregated | | sv_report_sample_recent_minmax | | sv_sample | +------------------------------------+
若是意外將你的web app 的DB指定成了log數據庫,則會在你的web app DB中加入以上數據表,並將原web app DB中重名的數據表刪除。這將是災難性的!
4. 將mycheckpoint配置成定時任務
* * * * * /usr/local/bin/mycheckpoint --user=root --password=xxxx --socket=/redmine/mysql/tmp/mysql.sock --database=mycheckpoint
5. http方式查看結果:
mycheckpoint --host=127.0.0.1 --port=3306 --user=root --password=xxxx --socket=/mysql/tmp/mysql.sock --database=mycheckpoint http
指定數據庫時需注意,切莫使用你的web app 的DB.
一個小時以後就能夠打開本地的http://localhost:12306/mycheckpoint 查看報表。
點評:
這個工具的優點是能將數據統計結果以web形式展示,可是因爲其依賴crontab,致使數據採集間隔過大,不能很好的描述mysql的運行情況, 另外,此工具已經於2014年4月中止更新。
其它的mysql第三方工具還有: percona-toolkit / mysqltuner.pl / tuning-primer.sh 等。
參考:
1. http://code.openark.org/forge/mycheckpoint
2. https://code.google.com/p/mycheckpoint/downloads/list