mysql运行监控全解课件

上传人:枫** 文档编号:567328368 上传时间:2024-07-20 格式:PPT 页数:28 大小:126KB
返回 下载 相关 举报
mysql运行监控全解课件_第1页
第1页 / 共28页
mysql运行监控全解课件_第2页
第2页 / 共28页
mysql运行监控全解课件_第3页
第3页 / 共28页
mysql运行监控全解课件_第4页
第4页 / 共28页
mysql运行监控全解课件_第5页
第5页 / 共28页
点击查看更多>>
资源描述

《mysql运行监控全解课件》由会员分享,可在线阅读,更多相关《mysql运行监控全解课件(28页珍藏版)》请在金锄头文库上搜索。

1、 MySQL Monitoring ChinaUnix网友技术交流网友技术交流 mysql运行监控全解课件 MySQL Monitoring 一、如何有效监控如何有效监控?监控的目的监控的目的 二、基本监控解决方案基本监控解决方案(基础数据收集基础数据收集) 三、高级解决方案高级解决方案(数据库健康状态,优化数据库健康状态,优化) 四、MySQL性能相关交互式监控工具性能相关交互式监控工具 五、相关资源参考相关资源参考mysql运行监控全解课件 一 、如何有效监控?一、如何有效监控一、如何有效监控?监控的目的监控的目的? 1 、服务健康监测(存活,故障告警.) 2 、监控系统采集数据,依据数据

2、进行调优 mysql运行监控全解课件 二、 基本监控解决方案二、基本监控解决方案(收集系统信息) top 、vmstat 、iostat 、mpstat 、mytop 、dstata 、free 、/proc/. 、mstat 、mtop .命令行工具分析系统资源使用状况.mysql运行监控全解课件 三、高级监控解决方案 三、高级监控解决方案三、高级监控解决方案 1、Nagios相关相关:(收集数据库信息及健康状态,对数据库调整优化收集数据库信息及健康状态,对数据库调整优化) check_mysql 推荐 nagios-mysql-plugins-0.3 适当选择 check_mysql_he

3、alth 重点介绍推荐重点介绍推荐 由于时间关系本由于时间关系本PPT只重点介绍一下只重点介绍一下Nagios相关的插件脚本相关的插件脚本. 重点介绍一下重点介绍一下check_mysql_health监控数据库调优。监控数据库调优。 2、MySQL Activity Report 基于rrdtool *http:/gert.sos.be/en/projects/mysqlar/ *http:/gert.sos.be/demo/mysqlar/ 演示网站mysql运行监控全解课件 三、高级监控解决方案 三、高级监控解决方案三、高级监控解决方案 3、CACTI * MySQL模板:http:/

4、4、RRD 参考资料: * http:/vvv.k6p.de/rrd/ * http:/oss.oetiker.ch/rrdtool/rrdworld/ * http:/www.fi.muni.cz/kas/mrtg-rrd/ * http:/www.tnpi.biz/internet/manage/rrdutil/faq/mysql.shtml 5、Munin * http:/munin.projects.linpro.no/ .mysql运行监控全解课件 Nagios check_mysql #cd /usr/local/nagios/libexec/ # ./check_mysql he

5、lp /查看使用说明查看使用说明.Usage: check_mysql -d database -H host -P port -s socket -u user -p password -SOptions: -h, -help Print detailed help screen -V, -version Print version information -H, -hostname=ADDRESS Host name, IP Address, or unix socket (must be an absolute path) -P, -port=INTEGER Port number (d

6、efault: 3306) -s, -socket=STRING Use the specified socket (has no effect if -H is used) -d, -database=STRING Check database with indicated name -u, -username=STRING Connect using the indicated username -p, -password=STRING Use the indicated password to authenticate the connection = IMPORTANT: THIS F

7、ORM OF AUTHENTICATION IS NOT SECURE! grant all privileges - on *.* - to identified by linuxtone;Query OK, 0 rows affected (0.00 sec)mysql flush privileges;Query OK, 0 rows affected (0.00 sec)mysql运行监控全解课件 Nagios check_mysql示例:示例:在监控机上在监控机上.#cd /usr/local/nagios/libexec/连接连接204查看数据库状态查看数据库状态:#./check

8、_mysql -H 192.168.169.204 -u netseek -p linuxtoneUptime: 2146510 Threads: 1 Questions: 61155591 Slow queries: 325 Opens: 1273 Flush tables: 1 Open tables: 767 Queries per second avg: 28.491连接数据库连接数据库123查看查看./check_mysql -H 192.168.169.123 -u netseek -p linuxtone -S -w 60 -c 600Uptime: 35349 Threads:

9、 1 Questions: 4022 Slow queries: 0 Opens: 38 Flush tables: 1 Open tables: 32 Queries per second avg: 0.114 Slave IO: Yes Slave SQL: Yes Seconds Behind Master: 0OK,在命令行下都能正常连接数据库:mysql运行监控全解课件Check_mysql Nagios配置# vi commands.cfg 添加如下:添加如下:#check_mysqldefine command command_name check_mysql command_l

10、ine $USER1$/check_mysql -H $ARG1$ -P $ARG2$ -u $ARG3$ -p $ARG4$ /仔细看参数传递与上面的命仔细看参数传递与上面的命令行对应令行对应. #check_slavedefine command command_name check_slave command_line $USER1$/check_mysql -H $ARG1$ -P $ARG2$ -u $ARG3$ -p $ARG4$ -S -w $ARG5$ -c $ARG6$ mysql运行监控全解课件Check_mysql Nagios配置#vi sh-wt-www-db.cfg

11、 给上海网通两台给上海网通两台DB服务器配置上服务器配置上mysql数据库检测数据库检测:. 在自己定的的配置文件里,添加如下服务段.#check_mysqldefine service host_name dbss-master service_description check_mysql check_command check_mysql!192.168.169.122!3306!netseek!linuxtone . #check slavedefine service host_name dbss-slave service_description check_slave check

12、_command check_slave!192.168.169.123!3306!netseek!linuxtone!60!600 . mysql运行监控全解课件 Nagios check_mysqlcheck_mysql监控演示效果Check_mysql S 模块可以很好的检测模块可以很好的检测mysql replication slave的健康状态的健康状态.mysqlshow slave stautsG*是否工作是否工作 Slave_IO_running: YES Slave_SQL_running: YES*延迟情况延迟情况 Sencodes_behind_mastermysql运行

13、监控全解课件 nagios-mysql-plugins选择性的使用此插件来配合监控工作选择性的使用此插件来配合监控工作# wget http:/www.shinguz.ch/MySQL/nagios-mysql-plugins-0.3.tar.gz# tar zxvf nagios-mysql-plugins-0.3.tar.gz# cd nagios-mysql-plugins-0.3# chmod a+x *# mv * /usr/local/nagios/libexec插件解释:check_db_mysql.pl 检测mysql是否运行.check_errorlog_mysql.pl 检

14、测数据库下的错误日志perf_mysql.pl 收集性能数据,类似后面要讲的check_mysql_healthreplication相关.check_repl_mysql_cnt_slave_hosts.pl /检测复制相关。check_repl_mysql_hearbeat.plcheck_repl_mysql_io_thread.plcheck_repl_mysql_read_exec_pos.plcheck_repl_mysql_readonly.plcheck_repl_mysql_seconds_behind_master.plcheck_repl_mysql_sql_thread

15、.pl-mysql运行监控全解课件 nagios-mysql-plugins./check_db_mysql.pl -h 192.168.169.204 -u netseek -p linuxtone -port 3306编写command define command command_name check_db_mysql command_line $USER1$/check_db_mysql.pl -h $ARG1$ -u $ARG2$ -p $ARG3$ -port $ARG4$ . 服务端配置: . check_command check_db_mysql!192.168.169.20

16、4!netseek!linuxtone!3306 .mysql运行监控全解课件 check_mysql_health 一、安装一、安装check_mysql_health 官方网站:http:/www.consol.de/opensource/nagios/check-mysql-health/ # wget http:/www.consol.de/fileadmin/opensource/Nagios/check_mysql_health-2.0.3.tar.gz # tar zxvf check_mysql_health-2.0.3.tar.gz # cd check_mysql_heal

17、th-2.0.3 # ./configure -prefix=/usr/local/nagios -with-nagios-user=nagios - with-nagios-group=nagios -with-perl -with-statefiles-dir=/tmp # make & make install 注注:check_mysql_health (check_mysql_perf的替代方案,官方不再支持的替代方案,官方不再支持 check_mysql_perf) 详细参见:http:/ mysql运行监控全解课件 check_mysql_health二、二、check_mysq

18、l_health 插件使用说明插件使用说明 # cd /usr/local/nagios/libexec/ # ./check_mysql_health -help Check various parameters of MySQL databases Usage: check_mysql_health -v -t -hostname -port | -socket -username -password -mode -method mysql check_mysql_health -h | -help check_mysql_health -V | -version mysql运行监控全解课

19、件 check_mysql_health . Options: -hostname the database servers hostname -port the databases port. (default: 3306) -socket the databases unix socket. -username the mysql db user -password the mysql db users password -database the databases name. (default: information_schema) -warning the warning rang

20、e -critical the critical range mysql运行监控全解课件 check_mysql_health .-mode the mode of the plugin. select one of the following keywords: connection-time (Time to connect to the server) 连接到服务器的时间连接到服务器的时间. uptime (Time the server is running) MySQL服务器运行的时间服务器运行的时间 threads-connected (Number of currently op

21、en connections) 数据库服器当前打开的连接数据库服器当前打开的连接 threadcache-hitrate (Hit rate of the thread-cache) 线程缓存命中率线程缓存命中率 -mysql replication 相关段相关段- slave-lag (Seconds behind master) 判断判断slave落后于落后于master多少秒多少秒 slave-io-running (Slave io running: Yes) 表明表明Slave复制正常运行复制正常运行 slave-sql-running (Slave sql running: Yes

22、) 表明表明Slave复制正常运行复制正常运行 用用check_mysql 模块来替代这些功能更模块来替代这些功能更,check_mysql是用是用C写的执行速度更快写的执行速度更快. -check-slave ./check_mysql -H 192.168.169.123 -u netseek -p linuxtone -S 来解决来解决mysql运行监控全解课件 check_mysql_health. -查询缓存相关查询缓存相关- qcache-hitrate (Query cache hitrate) 查询命中率查询命中率,这个比率越高则表明服务器的这个比率越高则表明服务器的SELEC

23、T 查询性能就越好查询性能就越好 qcache-lowmem-prunes (Query cache entries pruned because of low memory) 由于内存较小从缓存删除的查询数量由于内存较小从缓存删除的查询数量 增大增大query_cache_size的值,以减小的值,以减小lowmem,增加缓存命中率增加缓存命中率 keycache-hitrate (MyISAM key cache hitrate)n key缓存命中率缓存命中率 如果命中率低,则调大如果命中率低,则调大key_buffer_size -InnoDB Cache命中率命中率- bufferpo

24、ol-hitrate (InnoDB buffer pool hitrate) Innodb 缓冲池命中率缓冲池命中率 bufferpool-wait-free (InnoDB buffer pool waits for clean page available) Innodb的缓行的缓行冲池等待清理页冲池等待清理页. log-waits (InnoDB log waits because of a too small log buffer) 因为太小因为太小log缓冲区导致缓冲区导致inndob log等待等待. - mysql运行监控全解课件 check_mysql_health - ta

25、blecache-hitrate (Table cache hitrate) 表缓存命中率表缓存命中率 table-lock-contention(Table lock contention) 连接锁表率连接锁表率 table_locks_waited/table_locaks_immediate table_locak_waited:不能立即获得的表的锁表次数不能立即获得的表的锁表次数 table_locak_immediate: 立即获得的表的锁表次数立即获得的表的锁表次数. 小于小于1%较优,如果较优,如果1%需要引起注意,需要引起注意,3% 性能问题性能问题. index-usage

26、(Usage of indices) 索引使用情况索引使用情况. tmp-disk-tables (Percent of temp tables created on disk) 临时表创建临时表创建. slow-queries (Slow queries) 慢查询慢查询 long-running-procs (long running processes) 长期运行的进程长期运行的进程. cluster-ndbd-running (ndnd nodes are up and running) ndbd 集群节点运行状况集群节点运行状况 sql (any sql command returni

27、ng a single number) 执行返回一个数字的任何执行返回一个数字的任何SQL 。 告警值规则告警值规则: 10 means Alert, if 10 and 90: means Alert, if grant all privileges - on *.* - to identified by linuxtone;Query OK, 0 rows affected (0.00 sec)mysql flush privileges;Query OK, 0 rows affected (0.00 sec)OK - 2 client connection threads | threa

28、ds_connected=2;10;20mysql运行监控全解课件 check_mysql_health三、示例:三、示例:在监控机上在监控机上.#cd /usr/local/nagios/libexec/连接连接123查看数据库查询线程缓存命中率状态查看数据库查询线程缓存命中率状态:# ./check_mysql_health -hostname 192.168.169.123 -port 3306 -username netseek -password linuxtone -mode threadcache-hitrateOK - thread cache hitrate 91.30% |

29、 thread_cache_hitrate=91.30%;90:;80: thread_cache_hitrate_now=91.30% connections_per_sec=0.0090: 表示小于表示小于90 warning, 80 表示小于表示小于80 则则critical查询命中率查询命中率# ./check_mysql_health -hostname 192.168.169.122 -port 3306 -username netseek -password linuxtone -mode qcache-hitrateWARNING - query cache hitrate 8

30、8.19% | qcache_hitrate=88.19%;90:;80: qcache_hitrate_now=78.57% selects_per_sec=0.75mysql运行监控全解课件 check_mysql_health三、示例:三、示例:在监控机上在监控机上.调整告警调整告警阀值阀值:# ./check_mysql_health -hostname 192.168.169.122 -port 3306 -username netseek -password linuxtone -w 80: -c 70: -mode qcache-hitrateOK - query cache h

31、itrate 88.19% | qcache_hitrate=88.19%;80:;70: qcache_hitrate_now=85.63% selects_per_sec=0.52连接连接123数据库查看锁表率数据库查看锁表率.# ./check_mysql_health -hostname 192.168.169.123 -port 3306 -username netseek -password linuxtone -mode table-lock-contentionOK - table lock contention 0.00% | tablelock_contention=0.0

32、0%;1;2 tablelock_contention_now=0.00%连接连接123数据库查看数据库服务器当前连接数量数据库查看数据库服务器当前连接数量:# ./check_mysql_health -hostname 192.168.169.123 -port 3306 -username netseek -password linuxtone -mode threads-connectedOK - 2 client connection threads | threads_connected=2;10;20mysql运行监控全解课件 check_mysql_healthNagios相关

33、配置相关配置# vi commands.cfg 添加如下:添加如下:#check_health_mysqldefine command command_name check_mysql_health command_line $USER1$/check_mysql_health -hostname $ARG1$ -port $ARG2$ -username $ARG3$ -password $ARG4$ -mode $ARG5$ #vi sh-wt-www-db.cfg 给上海网通两台给上海网通两台DB服务器配置上服务器配置上mysql数据库检测数据库检测:. 在自己定的的配置文件里,添加如下

34、服务段在自己定的的配置文件里,添加如下服务段.define service host_name dbss-slave service_description threads-connected check_command check_mysql_health!192.168.169.123!3306!netseek!linuxtone!threads-connected mysql运行监控全解课件 check_mysql_health.define service host_name dbss-slave service_description qcache-hitrate check_com

35、mand check_mysql_health!192.168.169.123!3306!netseek!linuxtone!qcache-hitrate . define service host_name dbss-slave service_description keycache-hitrate check_command check_mysql_health!192.168.169.123!3306!netseek!linuxtone!keycache-hitrate . mysql运行监控全解课件 check_mysql_health演示效果演示效果更详细请参照官方文档更详细请参照

36、官方文档: http:/www.consol.de/opensource/nagios/check-mysql-healthmysql运行监控全解课件四、MySQL性能交互式监控工具 1、MySQL性能调优命令行工具介绍性能调优命令行工具介绍 * http:/ * http:/ * http:/ 操作文章参考操作文章参考: http:/bbs.linuxtone.org/thread-988-1-1.html * innotop: http:/ 2、慢查询日志分析、慢查询日志分析 * 如何记录慢查询日志如何记录慢查询日志 # vi /etc/f log-queries-not-using-in

37、dexes long_query_time = 10 log-slow-queries = /data/mysql/data/slow.log 3、慢查询日志分析工具、慢查询日志分析工具 mysqldumpslow , mysqlsla, myprofi, mysql-explain-slow-log, mysqllogfilter mysql运行监控全解课件 四、相关参考资源相关参考资源相关参考资源 1. monitoring_mysql_slides_en 2. MySQL Slow Tools 3. check_mysql.c 4. MySQL Monitoringmysql运行监控全解课件

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号