zabbix监控云端mysql等实例。

传统的mysql 服务器 用zabbix很容易实现,单对于云端的mysql 实例 我想大家都是用的云自带的监控。我们前端时间aws 云端mysql 实现主从 进程的出现问题,然而aws 自带的监控没有。

我们就想到 zabbix 实现对aws mysql 实例的监控。

1监控的服务远程去连接 awsmysql 取监控的数值就很容易实现了。

创建用户

GRANT USAGE,PROCESS,REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO [email protected]‘10.%‘ IDENTIFIED BY ‘zabbixtest‘;

2.监控客户端 zabbix配置文件的

serParameter=mysqlstatustest[*],/data/scripts/zabbix/mysql_check.sh "$1  $2  $3  $4"

3监控脚本重写。这个就是比较麻烦的事情 在这里我贡献给大家,我用的是zabbix3.2 版本实现的。

#!/bin/bash
mysql(){
  user=$2
  password=$3
  hostname=$4
  case $1 in
       Ping)
       /usr/bin/mysqladmin -u${user}  -p${password} -h${hostname}  ping 2>/dev/null |grep alive|wc -l
       ;;
       Threads)
       /usr/bin/mysqladmin   -u${user}  -p${password} -h${hostname}   status 2>/dev/null |cut -f3 -d":"|cut -f1 -d"Q"
       ;;
       Questions)
       /usr/bin/mysqladmin -u${user} -p${password} -h${hostname}  status 2>/dev/null |cut -f4 -d":"|cut -f1 -d"S"
       ;;
       Slowqueries)
       /usr/bin/mysqladmin -u${user} -p${password} -h${hostname}  status 2>/dev/null |cut -f5 -d":"|cut -f1 -d"O"
       ;;
       Qps)
       /usr/bin/mysqladmin -u${user} -p${password} -h${hostname}  status 2>/dev/null |cut -f9 -d":"
       ;;
       Slave_IO_State)
       if [ "$(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show slave status\G" 2>/dev/null | grep Slave_IO_Running|awk ‘{print $2}‘)" == "Yes" ];then echo 1; else echo 0;fi
       ;;
       Slave_SQL_State)
       if [ "$(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show slave status\G" 2>/dev/null | grep Slave_SQL_Running|grep -v "waiting for"|awk ‘{print $2}‘)" == "Yes" ];then echo 1; else echo 0;fi
       ;;
       SQL_Remaining_Delay)
       if [ "$(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show slave status\G" 2>/dev/null | grep SQL_Remaining_Delay|awk ‘{print $2}‘)" == "NULL" ];then echo 0; else echo "$(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show slave status\G" 2>/dev/null | grep SQL_Remaining_Delay|awk ‘{print $2}‘)" ;fi
       ;;
       Key_buffer_size)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘key_buffer_size‘;" 2>/dev/null | grep -v Value |awk ‘{print $2/1024^2}‘
       ;;
       Key_reads)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘key_reads‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘
       ;;
       Key_read_requests)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘key_read_requests‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘
       ;;
       Key_cache_miss_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘key_reads‘;" 2>/dev/null | grep -v Value|awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘key_read_requests‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk ‘{printf("%1.4f\n",$1/$2*100)}‘
       ;;
       Key_blocks_used)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}   -e "show status like ‘key_blocks_used‘;"  2>/dev/null |grep -v Value |awk ‘{print $2}‘ 
       ;;
       Key_blocks_unused)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}   -e "show status like ‘key_blocks_unused‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘
       ;;
       Key_blocks_used_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘key_blocks_used‘;" 2>/dev/null | grep -v
 Value |awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘key_blocks_unused‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk ‘{printf("%1.4f\n",$1/($1+$2)*100)}‘
       ;;
       Innodb_buffer_pool_size)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘innodb_buffer_pool_size‘;" 2>/dev/null |grep -v Value |awk ‘{print $2/1024^2}‘
       ;;
       Innodb_log_file_size)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘innodb_log_file_size‘;" 2>/dev/null |grep -v Value |awk ‘{print $2/1024^2}‘
       ;;
       Innodb_log_buffer_size)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘innodb_log_buffer_size‘;" 2>/dev/null |grep -v Value |awk ‘{print $2/1024^2}‘
       ;;
       Table_open_cache)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘table_open_cache‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Open_tables)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘open_tables‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Opened_tables)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘opened_tables‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Open_tables_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘open_tables‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘opened_tables‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk‘{printf("%1.4f\n",$1/($1+$2)*100)}‘
       ;;
       Table_open_cache_used_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘open_tables‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘table_open_cache‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk ‘{printf("%1.4f\n",$1/($1+$2)*100)}‘
       ;;
       Thread_cache_size)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘thread_cache_size‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Threads_cached)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Threads_cached‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Threads_connected)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Threads_connected‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Threads_created)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Threads_created‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Threads_running)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Threads_running‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Max_used_connections)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Max_used_connections‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Max_connections)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘Max_connections‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Max_connections_used_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Max_used_connections‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘max_connections‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk ‘{printf("%1.4f\n",$1/$2*100)}‘
        ;;
       Created_tmp_disk_tables)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘created_tmp_disk_tables‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Created_tmp_tables)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘created_tmp_tables‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Table_locks_immediate)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘table_locks_immediate‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Table_locks_waited)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘table_locks_waited‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Open_files)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘open_files‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Open_files_limit)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘open_files_limit‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Open_files_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘open_files‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘open_files_limit‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk ‘{printf("%1.4f\n",$1/$2*100)}‘
       ;;
       Com_select)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_select‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Com_insert)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_insert‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Com_insert_select)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_insert_select‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Com_update)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_update‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Com_replace)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_replace‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Com_replace_select)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_replace_select‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Table_scan_rate)
       echo $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_rnd_next‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘) $(/usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘com_select‘;" 2>/dev/null | grep -v Value |awk ‘{print $2}‘)| awk ‘{printf("%1.4f\n",$1/$2*100)}‘
       ;;
       Handler_read_first)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_first‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Handler_read_key)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_key‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Handler_read_next)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_next‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Handler_read_prev)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_prev‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Handler_read_rnd)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_rnd‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Handler_read_rnd_next)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Handler_read_rnd_next‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Sort_merge_passes)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Sort_merge_passes‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Sort_range)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Sort_range‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Sort_rows)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Sort_rows‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Sort_scan)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Sort_scan‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_free_blocks)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_free_blocks‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_free_memory)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_free_memory‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_free_blocks)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_free_blocks‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_hits)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_hits‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_inserts)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_inserts‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_lowmem_prunes)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_lowmem_prunes‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_not_cached)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_not_cached‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_queries_in_cache)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_queries_in_cache‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Qcache_total_blocks)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show status like ‘Qcache_total_blocks‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Query_cache_limit)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘query_cache_limit‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Query_cache_min_res_unit)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘query_cache_min_res_unit‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       Query_cache_size)
       /usr/bin/mysql -u${user} -p${password} -h${hostname}  -e "show variables like ‘query_cache_size,‘;" 2>/dev/null |grep -v Value |awk ‘{print $2}‘
       ;;
       *)
        echo $"Usage: ITMEname   dbuser  dbpass  dbhost";
    esac
}
mysql  $1 $2 $3 $4

mysql 需要连接的数据的 用户 和密码还有 ip 就需要在模版里面写宏变量实现。

4模版的添加 rate 有几个key 我没写。

模版在附件 zabbix 3.0才能使用此模版

如果需要redis和memcache 模版 和远程监控实现方法 请联系我。

5注意事项

由于 所以的 mysql 实例的监控都是从这一台zabbix-agentd 取的数值

所以这台监控的机器 的压力很大

StartPollersUnreachable=10 server 需要优化这个参数

客户端的配置文件 需要优化超时时间和buffer 大小

6tip

脚本优化方向,可以写个crontab 把状态数据 存到临时文件里面 ,然后脚本 取这个文件里面的数值,这样连接数能降低很多,因为时间仓促 所以脚本没优化。

我们的 这一台监控 mysql redis memcached 实例 都是用的这个方式,而且都是这个机器取的 50个实例的数值  (1核2gb的监控 客户端)同时还是一个zabbix-proxy。

时间: 2024-11-10 07:08:58

zabbix监控云端mysql等实例。的相关文章

zabbix -- 监控一台主机实例演示

早起的鸟儿有虫吃,周末早起的虫儿不被吃,嘿嘿.                     ---- 小 Q 1.创建主机 2.创建监控项 3. 查看监控数据 4.创建用户 短信(微信)脚本 ------------------------------------------------------------------------------------1.创建主机 configuration(配置)-->Hosts(主机)-->Create host(创建主机) 注:此之前要创建个主机群组,

zabbix监控多个tomcat实例--自动发现

参考:http://www.iyunv.com/thread-227674-1-1.html 1.上传 catalina-jmx-remote.jar, cmdline-jmxclient-0.10.3.jar, jmx_discovery.sh 和 add_service_tomcat.sh 到 /tmp/目录下 2.给 add_service_tomcat.sh 赋执行权限,并执行 执行完这个脚本之后,需要重启你的tomcat服务,和zabbix_agentd的服务 3  cat  add_

Mysql 监控 支持 mysql 多实例自动发现以及主从监控

在[/usr/local/zabbix327/bin] 目录下新建python文件,并增加执行权限,如下: #!/usr/bin/env /usr/bin/python # _*_ coding:utf-8 _*_ import subprocess import json import re import ConfigParser def main(): # mysqld is started with mysqld_safe ,and with the configfile,or use 3

zabbix监控mysql多实例和mariadb自定义脚本及其部署

最近新部署zabbix监控,发现有很多DB服务器都是mysql多实例的状态,mpm默认的mysql监控无法有效的监控mysql的运行状态和复制关系,故针对双实例的mysql制作的手工的zabbix脚本监控如下 首先新建新的zabbix的mysql多实例监控模板,操作如下 名称 为模板信息名称 类型 因为使用的脚本出发所以修改成zabbix捉捕器 键值 脚本返回的信息,可以为数值,也可以是字元,这里定义为字元 数据类型 字元 同时也可以设置主动捕捉,如下:监控多实例端口状态 名称 为模板信息名称

Zabbix监控之低级自动发现以及MySQL多实例

概述 Zabbix的网络发现是指zabbix server通过配置好的规则,自动添加host,group,template Zabbix的主动注册刚好和网络发现是相反的,功能基本一致.zabbix agent主动联系zabbix server,server自动添加host,group,template 以上两种方式都是发现host,添加host,而low-level discovery(低级自动发现)更加底层,用于发现item,trigger,graph等等. 2.MySQL多实例的低级自动发现

如何在Zabbix上安装MySQL监控插件PMP

PMP,全称是Percona Monitoring Plugins,是Percona公司为MySQL监控写的插件.支持Nagios,Cacti.从PMP 1.1开始,支持Zabbix. 下面,看看如何在Zabbix上安装PMP. 配置Zabbix Agent 下载PMP 下载地址:https://www.percona.com/downloads/percona-monitoring-plugins/ 因为我的Linux版本是RHEL 6.7,故选择RPM包 # wget https://www

zabbix日常监控项mysql(七)

参考文档: percona官方文档:https://www.percona.com/doc/percona-monitoring-plugins/LATEST/zabbix/index.html zabbix2.4的安装方法:https://www.cnblogs.com/irockcode/p/6752316.html 其他博主文档:http://blog.51cto.com/xiaozhagn/2059713 centos7.4客户端安装agent http://blog.csdn.net/

zabbix低级自动发现之mysql多实例

1.低级自动发现概述 zabbix的低级自动发现(LLD)适用于监控多实例,监控变化的数据(分区.网卡). 自动发现(LLD)提供了一种在计算机上为不同实体自动创建监控项,触发器和图形的方法.例如,Zabbix可以在你的机器上自动开始监控文件系统或网络接口,而无需为每个文件系统或网络接口手动创建监控项.此外,可以配置Zabbix根据定期执行发现后的得到实际结果,来移除不需要的监控项. 在zabbix中,支持六种类型的发现项目: 系统文件的发现 网络接口的发现 CPU和CPU内核的发现 SNMP

Linux系统搭建zabbix监控系统实例讲解

第一步,配置本地yum仓库,如下 1,挂载,挂载光驱到/mnt mount /dev/cdrom /mnt2,创建目录 mkdir -p /repo/cos7dvd3,然后使用命令创建yum仓库文件,注意指定正确的软件源位置yum-config-manager --add-repo file:///repo/cos7dvd/4,使用 yum repolist命令检测刚创建的yum软件仓库是否正常.5,使用yum clean all 清空缓存(非必要步骤,在yum更新时使用)6,使用vim编辑器给