mariadb监控指标采集

本文详细探讨了MariaDB数据库的监控指标采集,包括关键性能参数如查询速度、连接数、内存使用及磁盘I/O等,旨在帮助管理员优化数据库性能和稳定性。
摘要由CSDN通过智能技术生成
#!/usr/bin/env python3
# -*- coding:utf8 -*-
# Author: light.wang
# Create Date: 2021-10-08 10:21:17
# Last Modified: 2021-10-09 17:52:17
# Description: 腾讯云mariadb指标采集,适用于centos7
import json
import pymysql


class TencentMariadb:

    def __init__(self, params):
        self.params = json.loads(json.dumps(params))

    # 数据库连接
    def mariadb_conn(self, sql):
        conn = pymysql.connect(
            host=self.params.get('parameters').get('ip'),
            user=self.params.get('parameters').get('user'),
            password=self.params.get('parameters').get('passwd'),
            port=self.params.get('parameters').get('port')
        )
        cursor = conn.cursor()
        cursor.execute(sql)
        cursor.close()
        conn.close()
        return cursor

    # 数据库名称
    def mariadb_name(self):
        sql = 'show databases;'
        return [i[0] for i in self.mariadb_conn(sql).fetchall() if i[0] not in ["information_schema", "mysql", "performance_schema", "sysdb"]]

    # 数据库版本
    def mariadb_version(self):
        sql = 'select version() from dual;'
        return self.mariadb_conn(sql).fetchone()[0]

    # 数据库HOME目录
    def basedir(self):
        sql = "show global variables like '%basedir%';"
        basedir_value = self.mariadb_conn(sql).fetchone()[1] if self.mariadb_conn(sql).fetchone() else ''
        return basedir_value

    # 查询日志
    def general_log_file(self):
        sql = "show global variables like '%general_log_file%';"
        general_log_file_value = self.mariadb_conn(sql).fetchone()[1] if self.mariadb_conn(sql).fetchone() else ''
        return general_log_file_value

    # 慢查询日志
    def slow_query_log_file(self):
        sql = "show variables like 'slow_query_log_file';"
        return self.mariadb_conn(sql).fetchone()[1]

    # 二进制日志
    def log_bin_basename(self):
        sql 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值