forked from log2akshat/UsefulScripts
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMySQLTracker.py
More file actions
134 lines (107 loc) · 5.29 KB
/
MySQLTracker.py
File metadata and controls
134 lines (107 loc) · 5.29 KB
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
#!/usr/bin/python
## MySQL Status Script.
## Date : 06 February 2017
## Author : Akshat Singh
## akshat-pg8@iiitmk.ac.in
# Copyright (C) <2017> <Akshat Singh>
# <akshat-pg8@iiitmk.ac.in>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
#
import os
import time
import logging
import datetime
import argparse
import subprocess
from argparse import RawTextHelpFormatter
# MySQL Credentials
DB_HOST = 'localhost'
DB_USER = 'root'
DBHOST = "localhost"
DB_USER_PASSWORD = 'topSecret'
TIMESTAMP = time.strftime('%d-%m-%Y_%H:%M:%S')
def is_valid_loggingStatus(parser, arg):
"Function for checking logging status is valid or not."
if not (arg == 'on' or arg == 'off'):
parser.error('{} is not a valid input for turning logging on or off! Please specify \"on\" for turning logging on and \"off\" for turning logging off.'.format(arg))
else:
return arg
## =========> Command line arguments parsing -- starts <========= ##
parser = argparse.ArgumentParser(description='*********************************************************************************************************\n********************** |MySQLTracker - MySQL Tracking Utility.| **********************\n*********************************************************************************************************\n\n* This script will do the following task.\n\n* It will list the status of the MySQL and shows the processlist of the given database.', formatter_class=RawTextHelpFormatter)
parser.add_argument('-d','--database_name', help='MANDATORY : Name of the database.', required=True, metavar='<Database Name>')
parser.add_argument('-l','--log_file', help='Path of the log file.', metavar='<Log File>')
parser.add_argument('-ls', '--logging_onoff', help='Logging status On/Off', metavar='<Logging on/off>', type=lambda x: is_valid_loggingStatus(parser, x))
args = parser.parse_args()
## =========> Command line arguments parsing -- ends <========= ##
dbName = args.database_name
## =========> Logging Configurations -- starts <========= ##
loggerFile = args.log_file
loggingStatus = args.logging_onoff
logDirectory = "/var/log/"
if not loggerFile:
if not os.path.exists(logDirectory):
os.makedirs(logDirectory)
Log_File = logDirectory + 'MySQLTracker.log'
else:
Log_File = loggerFile + ".log"
# create logger
logger = logging.getLogger('MySQLTracker')
logger.setLevel(logging.DEBUG)
# Turning logging on or off
if loggingStatus:
if loggingStatus == 'off':
logger.disabled = True
else:
logger.disabled = False
else:
logger.disabled = False
# add a file handler
fileHandler = logging.FileHandler(Log_File)
fileHandler.setLevel(logging.DEBUG)
# create console handler and set level to debug
consoleHandler = logging.StreamHandler()
consoleHandler.setLevel(logging.DEBUG)
# create formatter
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s', datefmt='%m/%d/%Y %I:%M:%S %p')
# add formatter to handlers
fileHandler.setFormatter(formatter)
consoleHandler.setFormatter(formatter)
# add ch to logger
logger.addHandler(fileHandler)
logger.addHandler(consoleHandler)
## =========> Logging Configurations -- ends <========= ##
subprocess.call(["clear"])
# Function to show the processes of the given database.
def showProcessList():
logger.debug("Showinng current connections on MySQL..")
mysqlCmd = subprocess.Popen(["mysqladmin -u " + DB_USER + " -h" + DBHOST + " -p'" + DB_USER_PASSWORD + "' processlist"], shell=True, stdout=subprocess.PIPE,)
grepCmd = subprocess.Popen(['grep', dbName], stdin=mysqlCmd.stdout, stdout=subprocess.PIPE,)
mysqlCmd.stdout.close()
currentProcesses = str(grepCmd.communicate()[0]).strip()
print("+-----+------+-------------------+----------+---------+-------+-------+------------------+----------+")
print("| Id | User | Host | db | Command | Time | State | Info | Progress |")
print("+-----+------+-------------------+----------+---------+-------+-------+------------------+----------+")
print currentProcesses + "\n"
# Start taking the databases backup..
def MySQLStatus():
# Function for taking the database backups.
#dumpcmd = "mysqladmin -u " + DB_USER + " -h" + DBHOST + " -p'" + DB_USER_PASSWORD + "' status extended-status "
dumpcmd = "mysqladmin -u " + DB_USER + " -h" + DBHOST + " -p'" + DB_USER_PASSWORD + "' status "
print("\n\n+----------+------+-------------------+------------- MySQL STATUS - STARTS ---------+------------+------------+------------------+----------+")
os.system(dumpcmd)
print("+----------+------+-------------------+------------- MySQL STATUS - ENDS -----------+------------+------------+------------------+----------+\n\n")
showProcessList()
# Executing the script.
if __name__ == "__main__":
MySQLStatus()