mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 14:54:20 +01:00
184 lines
5.1 KiB
Python
Executable file
184 lines
5.1 KiB
Python
Executable file
#!/usr/bin/env python
|
|
|
|
import sys
|
|
import time
|
|
import re
|
|
import MySQLdb
|
|
import os.path
|
|
|
|
|
|
# run as
|
|
# [tcallaghan@mork ~]$ tokufilecheck.py --socket=/tmp/tmc.sock --user=root --datadir=$DB_DIR/data/
|
|
|
|
|
|
|
|
def usage():
|
|
print "check for filesystem issues"
|
|
print "[--socket=SOCKET]"
|
|
print "[--port=PORT]"
|
|
print "[--user=USERNAME]"
|
|
print "[--password=PASSWORD]"
|
|
print "[--datadir=<full-path-to-mysql-data-directory>]"
|
|
return 1
|
|
|
|
|
|
# check that each file in our file map exists in the file system
|
|
def check_file_map(rs, datadir):
|
|
print "checking that all files in our file map exist in the file system"
|
|
filesExisting = 0
|
|
filesMissing = 0
|
|
|
|
for t in rs:
|
|
dictName = t[0]
|
|
fileName = t[1]
|
|
if os.path.isfile(os.path.join(datadir, fileName)):
|
|
#print datadir + fileName + " exists"
|
|
filesExisting += 1
|
|
else:
|
|
print " *** " + datadir + fileName + " is missing"
|
|
filesMissing += 1
|
|
|
|
print " %d file(s) found | %d file(s) missing." % (filesExisting, filesMissing)
|
|
|
|
|
|
# check if a .tokudb file exists in our file map
|
|
def lookup_tokudb(rs, checkFileName):
|
|
fileExists = False
|
|
|
|
for t in rs:
|
|
if (t[1] == checkFileName):
|
|
fileExists = True
|
|
break
|
|
|
|
return fileExists
|
|
|
|
|
|
# check that all .frm files exist
|
|
def check_frm(rs, datadir):
|
|
print "checking that all .frm files exist"
|
|
filesExisting = 0
|
|
filesMissing = 0
|
|
|
|
for t in rs:
|
|
databaseName = t[0]
|
|
tableName = t[1]
|
|
storageEngine = t[2]
|
|
if os.path.isfile(os.path.join(datadir + os.sep + databaseName, tableName + '.frm')):
|
|
#print datadir + fileName + " exists"
|
|
filesExisting += 1
|
|
else:
|
|
print " *** missing FRM file for table " + tableName + " in database " + databaseName
|
|
filesMissing += 1
|
|
|
|
print " %d file(s) found | %d file(s) missing." % (filesExisting, filesMissing)
|
|
|
|
|
|
# check if a .tokudb file exists in our file map
|
|
def lookup_frm(rs, tableName, dbName):
|
|
frmExists = False
|
|
|
|
for t in rs:
|
|
if ((t[0] == dbName) and (t[1] == tableName)):
|
|
frmExists = True
|
|
break
|
|
|
|
return frmExists
|
|
|
|
|
|
def main():
|
|
host = "localhost"
|
|
socket = None
|
|
port = None
|
|
user = None
|
|
passwd = None
|
|
datadir = "./"
|
|
|
|
for a in sys.argv[1:]:
|
|
if a == "-h" or a == "-?" or a == "--help":
|
|
return usage()
|
|
match = re.match("--(.*)=(.*)", a)
|
|
if match:
|
|
exec "%s='%s'" % (match.group(1),match.group(2))
|
|
continue
|
|
return usage()
|
|
|
|
connect_parameters = {}
|
|
if socket is not None:
|
|
connect_parameters['unix_socket'] = socket
|
|
if port is not None:
|
|
connect_parameters['host'] = host
|
|
connect_parameters['port'] = int(port)
|
|
if user is not None:
|
|
connect_parameters['user'] = user
|
|
if passwd is not None:
|
|
connect_parameters['passwd'] = passwd
|
|
|
|
datadir = os.path.normpath(datadir) + os.sep
|
|
|
|
try:
|
|
db = MySQLdb.connect(**connect_parameters)
|
|
except:
|
|
print sys.exc_info()
|
|
return 1
|
|
|
|
print "connected to MySQL"
|
|
|
|
print "retrieving file map"
|
|
try:
|
|
q = 'select * from information_schema.tokudb_file_map'
|
|
c = db.cursor()
|
|
n = c.execute(q)
|
|
rsFileMap = c.fetchall()
|
|
db.commit()
|
|
c.close()
|
|
except MySQLdb.Error, e:
|
|
print " ** Error %d: %s" % (e.args[0], e.args[1])
|
|
return 2
|
|
except:
|
|
print "db", sys.exc_info()
|
|
return 2
|
|
|
|
print "retrieving full table listing"
|
|
try:
|
|
q = "select table_schema, table_name, engine from information_schema.tables where table_schema != 'information_schema'"
|
|
c = db.cursor()
|
|
n = c.execute(q)
|
|
rsTables = c.fetchall()
|
|
db.commit()
|
|
c.close()
|
|
except MySQLdb.Error, e:
|
|
print " ** Error %d: %s" % (e.args[0], e.args[1])
|
|
return 2
|
|
except:
|
|
print "db", sys.exc_info()
|
|
return 2
|
|
|
|
check_file_map(rsFileMap, datadir);
|
|
check_frm(rsTables, datadir);
|
|
|
|
print "checking for extra .frm and/or .tokudb files"
|
|
|
|
extraFrm = 0
|
|
extraTokudb = 0
|
|
|
|
for (path, dirs, files) in os.walk(datadir):
|
|
for file in files:
|
|
if (file.endswith('.frm')):
|
|
tableName = os.path.splitext(file)[0]
|
|
dbName = os.path.basename(os.path.normpath(path))
|
|
if not lookup_frm(rsTables, tableName, dbName):
|
|
extraFrm += 1
|
|
print "found .frm file for tableName / dbName = %s / %s" % (tableName, dbName)
|
|
if (file.endswith('.tokudb')):
|
|
# check that it exists in rsFileMap
|
|
checkFileName = "./" + file
|
|
if not lookup_tokudb(rsFileMap, checkFileName):
|
|
extraTokudb += 1
|
|
print " ** found extra .tokudb file %s" % (checkFileName)
|
|
|
|
print " %d unmatched .frm file(s) found" % (extraFrm)
|
|
print " %d unmatched .tokudb file(s) found" % (extraTokudb)
|
|
|
|
return 0
|
|
|
|
sys.exit(main())
|