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

[经验分享] zabbix 监控Mysql

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-12-26 08:57:38 | 显示全部楼层 |阅读模式
Zabbix 采集mysql的方法有很多,常用的是通过python、shell执行show status 或者show global status 获取值
二者的区别:
Show status;是当前的会话,你查看到的很多参数都是为0
Show global status;是你全局的会话,你重启数据库或者关闭都会失效
所以,再采集数据的时候,以global status 为主
简单的脚本如下(只采集Com_select,delete,update,rollback为列)
#!/usr/bin/env python
import os
def mysql_info(Source,socket,Items):
        User,Password,port = Source
        mysqladmin=os.popen('which mysqladmin').read().strip()
        comm='%s  -u%s -p%s -P%s -S%s  extended-status | grep -w "%s"|cut -d "|" -f 3' \
        %(mysqladmin,User,Password,port,socket,Items)
        Value=float(os.popen(comm).read().strip())
        print Value
if __name__ == '__main__':
        item = sys.argv[1]
        Source=['root','ema',3306]
        socket="/var/mysql/data/mysql.sock"
        mysql_info(Source,socket,item)
这个只是一个简单的脚本,还有很多优化和调整的地方
执行结果:
[iyunv@DB-Server ~]# python test.py Com_select
Warning: Using a password on the command line interface can be insecure.
3714689.0
Ok,把我们的脚本加入到zabbix的UserParameter.conf配置文件中
UserParameter=mysql_info
  • ,/usr/bin/python /usr/local/zabbix/script/test.py $1
    重启zabbix_agentd
    在zabbix_server上,通过zabbix_get 调试看看是否可以获取到这个值
    zabbix_get -s 10.132.63.37 -p 10050 -k 'mysql_info[,Com_select]'               
    3714889.0
    OK,现在是可以获取到这个值,接下来就是去创建items了
    QQ截图20141226085636.png

    看graph 动态显示数据
    QQ截图20141226085652.png


    会发现有很多0.000??多少的qps,这个数据是怎么来的呢
    去查看了下zabbix的history的表
    SQL 语句(没有优化):
    select itemid,from_unixtime(clock,'%Y%m%d %H:%i:%S') ,value from history where itemid=27077 and from_unixtime(clock,'%Y%m%d %H:%i:%S') > "20141225 14:00:00";
    |  27077 | 20141225 16:27:17 | 0.4531 |
    |  27077 | 20141225 16:28:17 | 0.7770 |
    |  27077 | 20141225 16:29:17 | 0.5366 |
    |  27077 | 20141225 16:30:17 | 5.7420 |
    |  27077 | 20141225 16:31:17 | 2.4279 |
    |  27077 | 20141225 16:32:17 | 0.4173 |
    |  27077 | 20141225 16:35:17 | 0.6591 |
    |  27077 | 20141225 16:36:17 | 0.3716 |
    |  27077 | 20141225 16:37:17 | 0.4951 |
    |  27077 | 20141225 16:38:17 | 0.3676 |
    |  27077 | 20141225 16:39:17 | 0.4194 |
    |  27077 | 20141225 16:40:17 | 0.3968 |
    |  27077 | 20141225 16:41:17 | 0.3667
    每分钟都是去采集一次,但怎么计算的呢
    我比较笨的方法就是在server上通过zabbix_get获取值,再除去采集的时间,发现数据大致类似
    所以,总结如下:这个值的计算是通过两次计算采集到数据的差值(zabbix_get 间隔1分钟去采集数据),再除去你的间隔时间就是每秒的qps
    所以,假设你采集数据的间隔为1分钟,如果你采集到的值在这一分钟内没有超过60,就会是1以下的数据

    以上是个人监控MYSQL时的简单记录,如果有错误的地方,还请指出!


  • 运维网声明 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-38864-1-1.html 上篇帖子: Zabbix_Proxy可用性图片灰色 下篇帖子: zabbix2.4.2实战监控mysql5.6性能 监控
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

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

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

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

    扫描微信二维码查看详情

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


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


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


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



    合作伙伴: 青云cloud

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