# # @copyright Copyright (c) 2024, Pietro Marini (pmarini@rcasys.com) # # @license GNU AGPL version 3 or any later version # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as # published by the Free Software Foundation, either version 3 of the # License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. # import pandas as pd import mariadb as mdb import configparser from functions import get_param config = configparser.ConfigParser() config.read("/var/lib/zabbix/.my.cnf") nc_usr = config["client"].get("user") nc_usr_pwd = config["client"].get("password") param_file = "/var/lib/zabbix/params.json" nc_db = get_param(param_file,"nc_db") nc_host = get_param(param_file,"nc_host") nc_db_port = get_param(param_file,"nc_db_port") conn = mdb.connect( user=nc_usr, password=nc_usr_pwd, host=nc_host, port=nc_db_port, database=nc_db ) cur = conn.cursor() cur.execute( """ SELECT TABLE_NAME AS table_name, TABLE_ROWS AS nr_rows, (DATA_LENGTH + INDEX_LENGTH) / 1024 / 1024 AS size_mb FROM information_schema.TABLES WHERE TABLE_SCHEMA='%s' ORDER BY size_mb DESC LIMIT 5 """ % nc_db ) df = pd.DataFrame( cur.fetchall(), columns=["table_name","nr_rows","size_mb"] ) df.to_json( "/var/lib/zabbix/output/db_metrics.json", orient='columns')