设为首页 收藏本站
查看: 1250|回复: 0

[经验分享] zabbix企业应用之low level discovery监控mysql

[复制链接]

尚未签到

发表于 2019-1-19 10:59:42 | 显示全部楼层 |阅读模式
  之前介绍了使用zabbix监控固定3306端口的mysql(文章地址为http://dl528888.blog.运维网.com/2382721/1346590),有个不好的地方是只能监控固定的3306端口,如果是非3306端口的话,需要修改模板,如果主机有多个mysql实例的话,需要具有不同的mysql模板,然后在管理监控,很是麻烦,为了解决这个问题,我使用lld(low level discovery)方式监控mysql,只需要你在正则表达式里把需要监控的端口标上,就可以监控mysql多实例。
  下面是监控效果图:
  1、整体图

  可以看到我这里是监控了3306与3307这2个mysql的实例,在图形上,是根据端口来进行区分。
  下面我只列举3307端口的监控效果图
  2、Mysql Sort of 3307 Port
  
  3、Mysql Bytes_sent Bytes_received of 3307 Port

  4、Mysql Com of 3307 Port

  5、Mysql Connectionsof 3307 Port

  6、Mysql Create tmp of 3307 Port

  7、Mysql Innodb of 3307 Port

  8、Mysql Key of 3307 Port

  9、Mysql Qcache of 3307 Port

  10、Mysql Queries and Questions of 3307 Port

  11、Mysql Slow of 3307 Port

  12、Mysql Sort of 3307 Port

  13、Mysql Uptime of 3307 Port

  如何实现:
  一、客户端
  1、监控内容的json化

  在客户端里,需要把监控的内容json化展示,然后服务端可以通过正则来过滤出结果
  下面在是我的json监控mysql的json展示

  脚本内容如下:
#!/bin/bash
#Fucation:mysql low-level discovery
#Script_name mysql_low_discovery.sh
mysql() {
port=($(sudo netstat -tpln | awk -F "[ :]+" '/[m]ysql/ && /0.0.0.0/ {print $5}'))
printf '{\n'
printf '\t"data":[\n'
for key in ${!port[@]}
do
if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];then
socket=`ps aux|grep ${port[${key}]}|grep -v grep|awk -F '=' '{print $10}'|cut -d ' ' -f 1`
printf '\t {\n'
printf "\t\t\t\"{#MYSQLPORT}\":\"${port[${key}]}\"},\n"
else [[ "${key}" -eq "((${#port[@]}-1))" ]]
socket=`ps aux|grep ${port[${key}]}|grep -v grep|awk -F '=' '{print $10}'|cut -d ' ' -f 1`
printf '\t {\n'
printf "\t\t\t\"{#MYSQLPORT}\":\"${port[${key}]}\"}\n"
fi
done
printf '\t ]\n'
printf '}\n'
}
$1  把此文件存放到/usr/local/zabbix/bin里,然后给与755权限,并修改用户与组为zabbix,同时允许zabbix用户无密码运行netstat

echo "zabbix ALL=(root) NOPASSWD:/bin/netstat">>/etc/sudoers  #Disable requiretty
sed -i 's/^Defaults.*.requiretty/#Defaults    requiretty/' /etc/sudoers  不关闭的话,会无法获取数据,并且zabbix日志里报

  2、修改zabbix_agentd.conf文件
  在zabbix_agentd.conf最后添加以下内容
UserParameter=zabbix_low_discovery
  • ,/bin/bash /usr/local/zabbix/bin/mysql_low_discovery.sh $1
    UserParameter=mysql_stats
  • ,mysql -h localhost -P $1 -uzabbix -pzabbix -e "show global status"|grep "\"|cut  -f2  测试

      如果你能通过/usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k zabbix_low_discovery[mysql]命令获取数据就代表没问题
    [root@zabbix1 bin]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k zabbix_low_discovery[mysql]
    {
    "data":[
    {
    "{#MYSQLPORT}":"3306"}
    ]
    }  3、mysql授权

    GRANT PROCESS ON *.* TO 'zabbix'@'localhost' identified BY 'zabbix';
    Flush privileges;  4、重启zabbix服务
    ps -ef|grep zabbix|grep -v grep|awk '{print $2}'|xargs kill -9
    /usr/local/zabbix/sbin/zabbix_agentd -c /usr/local/zabbix/conf/zabbix_agentd.conf  二、服务端

      1、模板导入
      把Template Mysql Auto Discovery导入到zabbix里(模板在附件),具体操作不介绍。
      2、设置正则
      在“管理”=》“一般”=》“正则表达式”里,选择“新的正则表达式”
      然后设置类似如下

      我这是运行3301到3309这9个mysql实例
      3、主机关联模板
      把需要监控mysql实例的主机管理模板即可监控,默认是3600秒后自动更新,如下图

      为什么设置3600秒?原因是如果设置时间过短,比如你设置60s,一个是服务器的压力大,一个是如果你检测的端口突然当掉了,还没有来的急报警,主机通过json来获取不到这个信息,就认为没有这个端口,模板里会自动关闭这个监控项的内容(默认保留30天,然后自动删除),这样报警功能就基本没有了,所以还是发现的间隔时间长一些比较好。
      



    附件:http://down.运维网.com/data/2364044


  • 运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
    2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
    3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
    4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
    5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
    6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
    7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
    8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

    所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-665115-1-1.html 上篇帖子: zabbix自动发现window(阿里云),去除多余的监控项 下篇帖子: zabbix邮件报警接入,微信报警接入
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    扫码加入运维网微信交流群X

    扫码加入运维网微信交流群

    扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

    扫描微信二维码查看详情

    客服E-mail:kefu@iyunv.com 客服QQ:1061981298


    QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


    提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


    本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



    合作伙伴: 青云cloud

    快速回复 返回顶部 返回列表