Xtradb+Haproxy高可用数据库集群(四)集群zabbix监控篇

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

xtradb cluster集群zabbix监控

监控指标

官网参考地址:

https://www.percona.com/doc/percona-xtradb-cluster/5.6/manual/monitoring.html

 

1、报警参数

每个集群节点状态:

wsrep_cluster_status != Primary

wsrep_connected != ON

wsrep_ready != ON

 

复制冲突过高

wsrep_local_cert_failures

wsrep_local_bf_aborts

 

流量控制信息

wsrep_flow_control_sent

wsrep_flow_control_recv

 

复制队列大小

wsrep_local_recv_queue

 

2、长期图表收集参数

队列大小

wsrep_local_recv_queue

 wsrep_local_send_queue

 

流量控制

wsrep_flow_control_sent

wsrep_flow_control_recv

 

本节点进出交换数量

wsrep_replicated

wsrep_received

 

进出交换的字节数

wsrep_replicated_bytes

wsrep_received_bytes

 

复制冲突

wsrep_local_cert_failures

wsrep_local_bf_aborts

 

 

Zabbix监控脚本

[root@yang-219 ~]# cat monit_xtradb.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/usr/bin/python env
#coding=utf-8
#time: 2015-8-12
#function: monit xtradb cluster status
#author: yangr
  
import  re,time,os
import  commands
###variable   数据库及监控项变量定义区域
mysql_user = 'sstuser'
mysql_pass = 's3cret'
mysql_host = 'localhost'
mysql_port = '3306'
monit_message = '''
wsrep_cluster_status
wsrep_connected
wsrep_ready
wsrep_local_cert_failures
wsrep_local_bf_aborts
wsrep_flow_control_sent
wsrep_flow_control_recv
wsrep_local_recv_queue
wsrep_local_recv_queue
wsrep_local_send_queue
wsrep_flow_control_sent
wsrep_flow_control_recv
wsrep_replicated
wsrep_received
wsrep_replicated_bytes
wsrep_received_bytes
wsrep_local_cert_failures
wsrep_local_bf_aborts
'''
monit_list = monit_message.split()
####zabbix 相关参数定义区域
zabbix_agent_file = '/usr/local/zabbix/etc/zabbix_agentd.conf'
zabbix_server = commands.getstatusoutput( '''grep '^ServerActive' %s|awk -F[=] '{print $2}' ''' % zabbix_agent_file)[ 1 ].strip()
zabbix_hostname = commands.getstatusoutput( '''grep '^Hostname' %s|awk -F[=] '{print $2}'  ''' % zabbix_agent_file)[ 1 ].strip()
zabbix_server_port = 10051
timestamp  =  int (time.time())
tmp_file_path = '/tmp/xtradb_cluster_status.txt'
zabbix_hostname = 'zabbix_server'
zabbix_server = 'zabbix_server'
  
####end variable变量定义结束
  
#获取全局状态信息
status,global_status = commands.getstatusoutput( ''' mysql -u%s -p%s -h%s -P%s -e 'show global status like "wsrep%%";' ''' % (mysql_user,mysql_pass,mysql_host,mysql_port))
#print ''' mysql -u%s -p%s -h%s -P%s -e 'show global status like "wsrep%%";' '''%(mysql_user,mysql_pass,mysql_host,mysql_port)
#print global_status
  
global_status = global_status.split( '\n' )
#print global_status
#清空文件
with  open (tmp_file_path, 'wb' ) as f:
          f.write('')
#循环要监控的指标
for  in  monit_list:
   #循环状态列表,取出指标当前的值
   for  in  global_status:
          if  "%s\t" % in  n:
                    value = re.sub(r '.*\t' ,'',n).strip()
                    #print i,'value:',value
                    #把值写入临时文件
                    with  open (tmp_file_path, 'ab' ) as f:
                             f.write( '%s %s %s %s\n' % (zabbix_hostname,i,timestamp,value))
         
#把临时文件通过zabbix_sender命令发送到server端
send_data_cmd = '/usr/local/zabbix/bin/zabbix_sender -vv -z %s -p %s -T -i %s' % (zabbix_server,zabbix_server_port,tmp_file_path)
print  '/usr/local/zabbix/bin/zabbix_sender -vv -z %s -p %s -T -i %s' % (zabbix_server,zabbix_server_port,tmp_file_path)
#print send_data_cmd
os.popen(send_data_cmd)


 

脚本里monit_message对应的监控项,需要在zabbix服务器上添加对应的监控项,然后把这个脚本放到crontab里每分钟执行一次即可。



     本文转自杨云1028 51CTO博客,原文链接:http://blog.51cto.com/yangrong/1684141,如需转载请自行联系原作者




相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
10天前
|
人工智能 容灾 关系型数据库
【AI应用启航workshop】构建高可用数据库、拥抱AI智能问数
12月25日(周三)14:00-16:30参与线上闭门会,阿里云诚邀您一同开启AI应用实践之旅!
|
1月前
|
监控 安全 前端开发
使用 Zabbix 监控堆外应用
使用 Zabbix 监控堆外应用
49 9
|
1月前
|
监控 数据可视化 Java
zabbix全面的监控能力
zabbix全面的监控能力
56 7
|
2月前
|
存储 数据库
快速搭建南大通用GBase 8s数据库SSC共享存储集群
本文介绍如何GBase8s 数据库 在单机环境中快速部署SSC共享存储集群,涵盖准备工作、安装数据库、创建环境变量文件、准备数据存储目录、修改sqlhost、设置onconfig、搭建sds集群及集群检查等步骤,助你轻松完成集群功能验证。
|
2月前
|
监控 Java Shell
监控堆外第三方监控工具Zabbix
监控堆外第三方监控工具Zabbix
40 5
|
2月前
|
Shell 数据库
GBase8a 数据库新集群第一次创建dblink
GBase8a 数据库新集群第一次创建dblink
|
2月前
|
SQL 数据库
GBase8a 数据库集群v953扩容案例问题分享
GBase8a 数据库集群v953扩容案例问题分享
|
2月前
|
存储 缓存 网络安全
南大通用GBase 8s 数据库 RHAC集群基本原理和搭建步骤
南大通用GBase 8s 数据库 RHAC集群基本原理和搭建步骤
|
2月前
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的数据库集群
PostgreSQL的逻辑存储结构涵盖了数据库集群、数据库、表、索引、视图等对象,每个对象都有唯一的oid标识。数据库集群是由单个PostgreSQL实例管理的所有数据库集合,共享同一配置和资源。集群的数据存储在一个称为数据目录的单一目录中,可通过-D选项或PGDATA环境变量指定。
|
2月前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
122 7

推荐镜像

更多