cdchenli 发表于 2019-1-20 10:34:46

zabbix 监控Mysql

  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%sextended-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
        Source=['root','ema',3306]
        socket="/var/mysql/data/mysql.sock"
        mysql_info(Source,socket,item)
  这个只是一个简单的脚本,还有很多优化和调整的地方
  执行结果:
# 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了
http://s3.运维网.com/wyfs02/M01/57/7D/wKioL1Sb0JejafqiAAKa3_p_BtI811.jpg
  
  看graph 动态显示数据
http://s3.运维网.com/wyfs02/M01/57/80/wKiom1Sbz-ryEFPnAAMXJBO126E598.jpg
  

  会发现有很多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]
查看完整版本: zabbix 监控Mysql