Simple Linux Panel
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mdserver-web/plugins/mysql/index.py

1961 lines
56 KiB

7 years ago
# coding:utf-8
import sys
import io
import os
import time
6 years ago
import subprocess
6 years ago
import re
6 years ago
import json
7 years ago
4 years ago
4 years ago
# reload(sys)
# sys.setdefaultencoding('utf-8')
6 years ago
7 years ago
sys.path.append(os.getcwd() + "/class/core")
import mw
7 years ago
6 years ago
4 years ago
if mw.isAppleSystem():
cmd = 'ls /usr/local/lib/ | grep python | cut -d \\ -f 1 | awk \'END {print}\''
info = mw.execShell(cmd)
p = "/usr/local/lib/" + info[0].strip() + "/site-packages"
sys.path.append(p)
6 years ago
app_debug = False
if mw.isAppleSystem():
6 years ago
app_debug = True
7 years ago
6 years ago
def getPluginName():
return 'mysql'
def getPluginDir():
return mw.getPluginDir() + '/' + getPluginName()
6 years ago
6 years ago
sys.path.append(getPluginDir() + "/class")
4 years ago
import mysqlDb
6 years ago
6 years ago
def getServerDir():
return mw.getServerDir() + '/' + getPluginName()
6 years ago
def getInitDFile():
if app_debug:
return '/tmp/' + getPluginName()
return '/etc/init.d/' + getPluginName()
4 years ago
def is_number(s):
try:
float(s)
return True
except ValueError:
pass
try:
import unicodedata
unicodedata.numeric(s)
return True
except (TypeError, ValueError):
pass
return False
6 years ago
def getArgs():
args = sys.argv[2:]
4 years ago
# print(args)
# if is_number(args):
# args = sys.argv[3:]
6 years ago
tmp = {}
args_len = len(args)
if args_len == 1:
t = args[0].strip('{').strip('}')
t = t.split(':')
tmp[t[0]] = t[1]
elif args_len > 1:
for i in range(len(args)):
t = args[i].split(':')
tmp[t[0]] = t[1]
return tmp
6 years ago
def checkArgs(data, ck=[]):
for i in range(len(ck)):
if not ck[i] in data:
return (False, mw.returnJson(False, '参数:(' + ck[i] + ')没有!'))
return (True, mw.returnJson(True, 'ok'))
6 years ago
6 years ago
def getConf():
6 years ago
path = getServerDir() + '/etc/my.cnf'
6 years ago
return path
4 years ago
def getInitdTpl(version=''):
path = getPluginDir() + '/init.d/mysql' + version + '.tpl'
6 years ago
return path
def contentReplace(content):
service_path = mw.getServerDir()
content = content.replace('{$ROOT_PATH}', mw.getRootDir())
6 years ago
content = content.replace('{$SERVER_PATH}', service_path)
6 years ago
content = content.replace('{$SERVER_APP_PATH}', service_path + '/mysql')
6 years ago
return content
6 years ago
def pSqliteDb(dbname='databases'):
6 years ago
file = getServerDir() + '/mysql.db'
name = 'mysql'
if not os.path.exists(file):
conn = mw.M(dbname).dbPos(getServerDir(), name)
csql = mw.readFile(getPluginDir() + '/conf/mysql.sql')
6 years ago
csql_list = csql.split(';')
for index in range(len(csql_list)):
conn.execute(csql_list[index], ())
else:
4 years ago
# 现有run
4 years ago
# conn = mw.M(dbname).dbPos(getServerDir(), name)
# csql = mw.readFile(getPluginDir() + '/conf/mysql.sql')
# csql_list = csql.split(';')
# for index in range(len(csql_list)):
# conn.execute(csql_list[index], ())
conn = mw.M(dbname).dbPos(getServerDir(), name)
6 years ago
return conn
def pMysqlDb():
4 years ago
db = mysqlDb.mysqlDb()
6 years ago
db.__DB_CNF = getConf()
4 years ago
db.setDbConf(getConf())
6 years ago
db.setPwd(pSqliteDb('config').where(
'id=?', (1,)).getField('mysql_root'))
return db
6 years ago
4 years ago
def initDreplace(version=''):
initd_tpl = getInitdTpl(version)
6 years ago
initD_path = getServerDir() + '/init.d'
if not os.path.exists(initD_path):
os.mkdir(initD_path)
file_bin = initD_path + '/' + getPluginName()
if not os.path.exists(file_bin):
content = mw.readFile(initd_tpl)
6 years ago
content = contentReplace(content)
mw.writeFile(file_bin, content)
mw.execShell('chmod +x ' + file_bin)
6 years ago
6 years ago
mysql_conf_dir = getServerDir() + '/etc'
6 years ago
if not os.path.exists(mysql_conf_dir):
os.mkdir(mysql_conf_dir)
mysql_conf = mysql_conf_dir + '/my.cnf'
if not os.path.exists(mysql_conf):
4 years ago
mysql_conf_tpl = getPluginDir() + '/conf/my' + version + '.cnf'
content = mw.readFile(mysql_conf_tpl)
6 years ago
content = contentReplace(content)
mw.writeFile(mysql_conf, content)
6 years ago
4 years ago
if mw.getOs() != 'darwin':
mw.execShell('chown -R mysql mysql ' + getServerDir())
6 years ago
return file_bin
7 years ago
4 years ago
def status(version=''):
data = mw.execShell(
6 years ago
"ps -ef|grep mysqld |grep -v grep | grep -v python | awk '{print $2}'")
7 years ago
if data[0] == '':
return 'stop'
return 'start'
6 years ago
def getDataDir():
file = getConf()
content = mw.readFile(file)
6 years ago
rep = 'datadir\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
6 years ago
def binLog():
args = getArgs()
conf = getConf()
con = mw.readFile(conf)
6 years ago
if con.find('#log-bin=mysql-bin') != -1:
4 years ago
if 'status' in args:
return mw.returnJson(False, '0')
6 years ago
con = con.replace('#log-bin=mysql-bin', 'log-bin=mysql-bin')
con = con.replace('#binlog_format=mixed', 'binlog_format=mixed')
mw.execShell('sync')
6 years ago
restart()
else:
path = getDataDir()
4 years ago
if 'status' in args:
6 years ago
dsize = 0
for n in os.listdir(path):
if len(n) < 9:
continue
if n[0:9] == 'mysql-bin':
dsize += os.path.getsize(path + '/' + n)
return mw.returnJson(True, dsize)
6 years ago
con = con.replace('log-bin=mysql-bin', '#log-bin=mysql-bin')
con = con.replace('binlog_format=mixed', '#binlog_format=mixed')
mw.execShell('sync')
6 years ago
restart()
mw.execShell('rm -f ' + path + '/mysql-bin.*')
6 years ago
mw.writeFile(conf, con)
return mw.returnJson(True, '设置成功!')
6 years ago
4 years ago
def setSkipGrantTables(v):
'''
设置是否密码验证
'''
conf = getConf()
con = mw.readFile(conf)
if v:
if con.find('#skip-grant-tables') != -1:
con = con.replace('#skip-grant-tables', 'skip-grant-tables')
else:
con = con.replace('skip-grant-tables', '#skip-grant-tables')
mw.writeFile(conf, con)
return True
6 years ago
def getErrorLog():
args = getArgs()
path = getDataDir()
filename = ''
for n in os.listdir(path):
if len(n) < 5:
continue
if n == 'error.log':
filename = path + '/' + n
break
4 years ago
# print filename
6 years ago
if not os.path.exists(filename):
return mw.returnJson(False, '指定文件不存在!')
4 years ago
if 'close' in args:
mw.writeFile(filename, '')
return mw.returnJson(False, '日志已清空')
4 years ago
info = mw.getNumLines(filename, 18)
return mw.returnJson(True, 'OK', info)
6 years ago
6 years ago
def getShowLogFile():
file = getConf()
content = mw.readFile(file)
6 years ago
rep = 'slow-query-log-file\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
6 years ago
def pGetDbUser():
if mw.isAppleSystem():
user = mw.execShell(
6 years ago
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
return user
return 'mysql'
6 years ago
def initMysqlData():
datadir = getDataDir()
if not os.path.exists(datadir + '/mysql'):
6 years ago
serverdir = getServerDir()
6 years ago
user = pGetDbUser()
6 years ago
cmd = 'cd ' + serverdir + ' && ./scripts/mysql_install_db --user=' + \
user + ' --basedir=' + serverdir + ' --ldata=' + datadir
mw.execShell(cmd)
6 years ago
return 0
return 1
4 years ago
def initMysql8Data():
datadir = getDataDir()
if not os.path.exists(datadir + '/mysql'):
serverdir = getServerDir()
user = pGetDbUser()
cmd = 'cd ' + serverdir + ' && ./bin/mysqld --basedir=' + serverdir + ' --datadir=' + \
datadir + ' --initialize'
mw.execShell(cmd)
return 0
return 1
6 years ago
def initMysqlPwd():
6 years ago
time.sleep(5)
6 years ago
6 years ago
serverdir = getServerDir()
pwd = mw.getRandomString(16)
6 years ago
cmd_pass = serverdir + '/bin/mysqladmin -uroot password ' + pwd
pSqliteDb('config').where('id=?', (1,)).save('mysql_root', (pwd,))
mw.execShell(cmd_pass)
6 years ago
return True
4 years ago
def initMysql8Pwd():
4 years ago
time.sleep(6)
4 years ago
3 years ago
# import MySQLdb as mdb
# dbconn = mdb.connect('localhost', 'root', '', '')
# dbconn.autocommit(True)
# dbcurr = dbconn.cursor()
# dbcurr.execute('SET NAMES UTF8MB4')
4 years ago
4 years ago
serverdir = getServerDir()
4 years ago
pwd = mw.getRandomString(16)
4 years ago
3 years ago
pass_cmd = "cat " + serverdir + \
"/data/error.log | grep root@localhost | awk -F 'root@localhost:' '{print $2}'"
passdata = mw.execShell(pass_cmd)
password = passdata[0].strip()
3 years ago
4 years ago
# with mysql_native_password
3 years ago
alter_root_pwd = "flush privileges;"
4 years ago
alter_root_pwd = alter_root_pwd + \
"alter user 'root'@'localhost' identified by '" + pwd + "';"
3 years ago
alter_root_pwd = alter_root_pwd + "flush privileges;"
3 years ago
# r = dbcurr.execute(alter_root_pwd)
3 years ago
tmp_file = "/tmp/mysql_init_tmp.log"
mw.writeFile(tmp_file, alter_root_pwd)
cmd_pass = serverdir + '/bin/mysql -uroot -p"' + password + '" < ' + tmp_file
print(cmd_pass)
mw.execShell(cmd_pass)
4 years ago
pSqliteDb('config').where('id=?', (1,)).save('mysql_root', (pwd,))
4 years ago
4 years ago
return True
6 years ago
def myOp(method):
4 years ago
# import commands
6 years ago
init_file = initDreplace()
6 years ago
cmd = init_file + ' ' + method
6 years ago
try:
initData = initMysqlData()
6 years ago
subprocess.Popen(cmd, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
4 years ago
if initData == 0:
6 years ago
initMysqlPwd()
6 years ago
return 'ok'
6 years ago
except Exception as e:
return str(e)
6 years ago
4 years ago
def my8cmd(version, method):
init_file = initDreplace(version)
cmd = init_file + ' ' + method
try:
initData = initMysql8Data()
if initData == 0:
4 years ago
setSkipGrantTables(True)
cmd_init_start = init_file + ' start'
subprocess.Popen(cmd_init_start, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
4 years ago
initMysql8Pwd()
4 years ago
cmd_init_stop = init_file + ' stop'
subprocess.Popen(cmd_init_stop, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
setSkipGrantTables(False)
my8cmd(version, method)
else:
3 years ago
if method == "stop":
mw.execShell(cmd)
3 years ago
return "ok"
3 years ago
subprocess.run(cmd, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
4 years ago
return 'ok'
except Exception as e:
print(e)
return 'fail'
def appCMD(version, action):
if version == '8.0':
return my8cmd(version, action)
return myOp(action)
4 years ago
def start(version=''):
4 years ago
return appCMD(version, 'start')
6 years ago
7 years ago
4 years ago
def stop(version=''):
4 years ago
return appCMD(version, 'stop')
7 years ago
4 years ago
def restart(version=''):
4 years ago
return appCMD(version, 'restart')
7 years ago
4 years ago
def reload(version=''):
4 years ago
return appCMD(version, 'reload')
7 years ago
6 years ago
def initdStatus():
if not app_debug:
if mw.isAppleSystem():
6 years ago
return "Apple Computer does not support"
initd_bin = getInitDFile()
if os.path.exists(initd_bin):
return 'ok'
return 'fail'
def initdInstall():
import shutil
if not app_debug:
if mw.isAppleSystem():
6 years ago
return "Apple Computer does not support"
mysql_bin = initDreplace()
initd_bin = getInitDFile()
shutil.copyfile(mysql_bin, initd_bin)
mw.execShell('chmod +x ' + initd_bin)
mw.execShell('chkconfig --add ' + getPluginName())
6 years ago
return 'ok'
def initdUinstall():
if not app_debug:
if mw.isAppleSystem():
6 years ago
return "Apple Computer does not support"
mw.execShell('chkconfig --del ' + getPluginName())
6 years ago
initd_bin = getInitDFile()
os.remove(initd_bin)
return 'ok'
7 years ago
def getMyDbPos():
file = getConf()
content = mw.readFile(file)
rep = 'datadir\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
def setMyDbPos():
args = getArgs()
data = checkArgs(args, ['datadir'])
if not data[0]:
return data[1]
s_datadir = getMyDbPos()
t_datadir = args['datadir']
if t_datadir == s_datadir:
return mw.returnJson(False, '与当前存储目录相同,无法迁移文件!')
if not os.path.exists(t_datadir):
mw.execShell('mkdir -p ' + t_datadir)
# mw.execShell('/etc/init.d/mysqld stop')
stop()
mw.execShell('cp -rf ' + s_datadir + '/* ' + t_datadir + '/')
4 years ago
mw.execShell('chown -R mysql mysql ' + t_datadir)
mw.execShell('chmod -R 755 ' + t_datadir)
mw.execShell('rm -f ' + t_datadir + '/*.pid')
mw.execShell('rm -f ' + t_datadir + '/*.err')
path = getServerDir()
myfile = path + '/etc/my.cnf'
mycnf = mw.readFile(myfile)
mw.writeFile(path + '/etc/my_backup.cnf', mycnf)
mycnf = mycnf.replace(s_datadir, t_datadir)
mw.writeFile(myfile, mycnf)
start()
result = mw.execShell(
'ps aux|grep mysqld| grep -v grep|grep -v python')
if len(result[0]) > 10:
mw.writeFile('data/datadir.pl', t_datadir)
return mw.returnJson(True, '存储目录迁移成功!')
else:
mw.execShell('pkill -9 mysqld')
mw.writeFile(myfile, mw.readFile(path + '/etc/my_backup.cnf'))
start()
return mw.returnJson(False, '文件迁移失败!')
6 years ago
def getMyPort():
file = getConf()
content = mw.readFile(file)
6 years ago
rep = 'port\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
6 years ago
6 years ago
def setMyPort():
args = getArgs()
data = checkArgs(args, ['port'])
if not data[0]:
return data[1]
6 years ago
port = args['port']
file = getConf()
content = mw.readFile(file)
6 years ago
rep = "port\s*=\s*([0-9]+)\s*\n"
content = re.sub(rep, 'port = ' + port + '\n', content)
mw.writeFile(file, content)
6 years ago
restart()
return mw.returnJson(True, '编辑成功!')
6 years ago
def runInfo():
4 years ago
if status(version) == 'stop':
return mw.returnJson(false, 'MySQL未启动', [])
6 years ago
db = pMysqlDb()
data = db.query('show global status')
6 years ago
gets = ['Max_used_connections', 'Com_commit', 'Com_rollback', 'Questions', 'Innodb_buffer_pool_reads', 'Innodb_buffer_pool_read_requests', 'Key_reads', 'Key_read_requests', 'Key_writes',
'Key_write_requests', 'Qcache_hits', 'Qcache_inserts', 'Bytes_received', 'Bytes_sent', 'Aborted_clients', 'Aborted_connects',
'Created_tmp_disk_tables', 'Created_tmp_tables', 'Innodb_buffer_pool_pages_dirty', 'Opened_files', 'Open_tables', 'Opened_tables', 'Select_full_join',
'Select_range_check', 'Sort_merge_passes', 'Table_locks_waited', 'Threads_cached', 'Threads_connected', 'Threads_created', 'Threads_running', 'Connections', 'Uptime']
6 years ago
try:
6 years ago
# print data
if data[0] == 1045 or data[0] == 2003:
pwd = db.getPwd()
return mw.returnJson(False, 'mysql password error:' + pwd + '!')
6 years ago
except Exception as e:
6 years ago
pass
result = {}
4 years ago
# print(data)
4 years ago
6 years ago
for d in data:
for g in gets:
if d[0] == g:
result[g] = d[1]
4 years ago
# print(result, int(result['Uptime']))
6 years ago
result['Run'] = int(time.time()) - int(result['Uptime'])
tmp = db.query('show master status')
try:
result['File'] = tmp[0][0]
result['Position'] = tmp[0][1]
except:
result['File'] = 'OFF'
result['Position'] = 'OFF'
return mw.getJson(result)
6 years ago
6 years ago
def myDbStatus():
result = {}
db = pMysqlDb()
data = db.query('show variables')
6 years ago
isError = isSqlError(data)
if isError != None:
return isError
4 years ago
gets = ['table_open_cache', 'thread_cache_size', 'key_buffer_size', 'tmp_table_size', 'max_heap_table_size', 'innodb_buffer_pool_size',
6 years ago
'innodb_additional_mem_pool_size', 'innodb_log_buffer_size', 'max_connections', 'sort_buffer_size', 'read_buffer_size', 'read_rnd_buffer_size', 'join_buffer_size', 'thread_stack', 'binlog_cache_size']
result['mem'] = {}
for d in data:
for g in gets:
if d[0] == g:
result['mem'][g] = d[1]
4 years ago
# if result['mem']['query_cache_type'] != 'ON':
# result['mem']['query_cache_size'] = '0'
return mw.getJson(result)
6 years ago
def setDbStatus():
4 years ago
gets = ['key_buffer_size', 'tmp_table_size', 'max_heap_table_size', 'innodb_buffer_pool_size', 'innodb_log_buffer_size', 'max_connections',
6 years ago
'table_open_cache', 'thread_cache_size', 'sort_buffer_size', 'read_buffer_size', 'read_rnd_buffer_size', 'join_buffer_size', 'thread_stack', 'binlog_cache_size']
4 years ago
emptys = ['max_connections', 'thread_cache_size', 'table_open_cache']
6 years ago
args = getArgs()
conFile = getConf()
content = mw.readFile(conFile)
6 years ago
n = 0
for g in gets:
s = 'M'
if n > 5:
s = 'K'
if g in emptys:
s = ''
rep = '\s*' + g + '\s*=\s*\d+(M|K|k|m|G)?\n'
c = g + ' = ' + args[g] + s + '\n'
if content.find(g) != -1:
content = re.sub(rep, '\n' + c, content, 1)
else:
content = content.replace('[mysqld]\n', '[mysqld]\n' + c)
n += 1
mw.writeFile(conFile, content)
return mw.returnJson(True, '设置成功!')
6 years ago
6 years ago
def isSqlError(mysqlMsg):
6 years ago
# 检测数据库执行错误
6 years ago
mysqlMsg = str(mysqlMsg)
if "MySQLdb" in mysqlMsg:
return mw.returnJson(False, 'MySQLdb组件缺失! <br>进入SSH命令行输入: pip install mysql-python')
6 years ago
if "2002," in mysqlMsg:
return mw.returnJson(False, '数据库连接失败,请检查数据库服务是否启动!')
4 years ago
if "2003," in mysqlMsg:
return mw.returnJson(False, "Can't connect to MySQL server on '127.0.0.1' (61)")
6 years ago
if "using password:" in mysqlMsg:
return mw.returnJson(False, '数据库管理密码错误!')
6 years ago
if "Connection refused" in mysqlMsg:
return mw.returnJson(False, '数据库连接失败,请检查数据库服务是否启动!')
6 years ago
if "1133" in mysqlMsg:
return mw.returnJson(False, '数据库用户不存在!')
6 years ago
if "1007" in mysqlMsg:
return mw.returnJson(False, '数据库已经存在!')
6 years ago
return None
6 years ago
def mapToList(map_obj):
# map to list
try:
if type(map_obj) != list and type(map_obj) != str:
map_obj = list(map_obj)
return map_obj
except:
return []
6 years ago
def __createUser(dbname, username, password, address):
pdb = pMysqlDb()
4 years ago
if username == 'root':
dbname = '*'
6 years ago
pdb.execute(
"CREATE USER `%s`@`localhost` IDENTIFIED BY '%s'" % (username, password))
pdb.execute(
"grant all privileges on %s.* to `%s`@`localhost`" % (dbname, username))
for a in address.split(','):
pdb.execute(
"CREATE USER `%s`@`%s` IDENTIFIED BY '%s'" % (username, a, password))
pdb.execute(
"grant all privileges on %s.* to `%s`@`%s`" % (dbname, username, a))
pdb.execute("flush privileges")
4 years ago
def getDbBackupListFunc(dbname=''):
bkDir = mw.getRootDir() + '/backup/database'
blist = os.listdir(bkDir)
r = []
bname = 'db_' + dbname
blen = len(bname)
for x in blist:
fbstr = x[0:blen]
if fbstr == bname:
r.append(x)
return r
4 years ago
def setDbBackup():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
scDir = mw.getRunDir() + '/scripts/backup.py'
cmd = 'python ' + scDir + ' database ' + args['name'] + ' 3'
os.system(cmd)
return mw.returnJson(True, 'ok')
4 years ago
def importDbBackup():
args = getArgs()
data = checkArgs(args, ['file', 'name'])
if not data[0]:
return data[1]
file = args['file']
name = args['name']
file_path = mw.getRootDir() + '/backup/database/' + file
file_path_sql = mw.getRootDir() + '/backup/database/' + file.replace('.gz', '')
if not os.path.exists(file_path_sql):
cmd = 'cd ' + mw.getRootDir() + '/backup/database && gzip -d ' + file
mw.execShell(cmd)
pwd = pSqliteDb('config').where('id=?', (1,)).getField('mysql_root')
mysql_cmd = mw.getRootDir() + '/server/mysql/bin/mysql -uroot -p' + pwd + \
' ' + name + ' < ' + file_path_sql
# print(mysql_cmd)
os.system(mysql_cmd)
return mw.returnJson(True, 'ok')
4 years ago
def deleteDbBackup():
args = getArgs()
data = checkArgs(args, ['filename'])
if not data[0]:
return data[1]
bkDir = mw.getRootDir() + '/backup/database'
os.remove(bkDir + '/' + args['filename'])
return mw.returnJson(True, 'ok')
def getDbBackupList():
4 years ago
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
r = getDbBackupListFunc(args['name'])
bkDir = mw.getRootDir() + '/backup/database'
rr = []
4 years ago
for x in range(0, len(r)):
4 years ago
p = bkDir + '/' + r[x]
data = {}
data['name'] = r[x]
rsize = os.path.getsize(p)
data['size'] = mw.toSize(rsize)
t = os.path.getctime(p)
t = time.localtime(t)
data['time'] = time.strftime('%Y-%m-%d %H:%M:%S', t)
rr.append(data)
4 years ago
data['file'] = p
4 years ago
return mw.returnJson(True, 'ok', rr)
6 years ago
def getDbList():
args = getArgs()
page = 1
page_size = 10
search = ''
data = {}
if 'page' in args:
page = int(args['page'])
if 'page_size' in args:
page_size = int(args['page_size'])
if 'search' in args:
search = args['search']
conn = pSqliteDb('databases')
limit = str((page - 1) * page_size) + ',' + str(page_size)
condition = ''
if not search == '':
condition = "name like '%" + search + "%'"
field = 'id,pid,name,username,password,accept,ps,addtime'
clist = conn.where(condition, ()).field(
field).limit(limit).order('id desc').select()
4 years ago
4 years ago
for x in range(0, len(clist)):
4 years ago
dbname = clist[x]['name']
blist = getDbBackupListFunc(dbname)
# print(blist)
clist[x]['is_backup'] = False
if len(blist) > 0:
clist[x]['is_backup'] = True
6 years ago
count = conn.where(condition, ()).count()
_page = {}
_page['count'] = count
_page['p'] = page
_page['row'] = page_size
_page['tojs'] = 'dbList'
data['page'] = mw.getPage(_page)
6 years ago
data['data'] = clist
info = {}
info['root_pwd'] = pSqliteDb('config').where(
'id=?', (1,)).getField('mysql_root')
data['info'] = info
return mw.getJson(data)
6 years ago
6 years ago
def syncGetDatabases():
pdb = pMysqlDb()
6 years ago
psdb = pSqliteDb('databases')
data = pdb.query('show databases')
isError = isSqlError(data)
if isError != None:
return isError
users = pdb.query(
"select User,Host from mysql.user where User!='root' AND Host!='localhost' AND Host!=''")
nameArr = ['information_schema', 'performance_schema', 'mysql', 'sys']
n = 0
for value in data:
b = False
for key in nameArr:
if value[0] == key:
b = True
break
if b:
continue
if psdb.where("name=?", (value[0],)).count():
continue
host = '127.0.0.1'
for user in users:
if value[0] == user[0]:
host = user[1]
break
ps = mw.getMsg('INPUT_PS')
6 years ago
if value[0] == 'test':
ps = mw.getMsg('DATABASE_TEST')
6 years ago
addTime = time.strftime('%Y-%m-%d %X', time.localtime())
6 years ago
if psdb.add('name,username,password,accept,ps,addtime', (value[0], value[0], '', host, ps, addTime)):
6 years ago
n += 1
msg = mw.getInfo('本次共从服务器获取了{1}个数据库!', (str(n),))
return mw.returnJson(True, msg)
6 years ago
6 years ago
6 years ago
def toDbBase(find):
pdb = pMysqlDb()
psdb = pSqliteDb('databases')
if len(find['password']) < 3:
find['username'] = find['name']
find['password'] = mw.md5(str(time.time()) + find['name'])[0:10]
6 years ago
psdb.where("id=?", (find['id'],)).save(
'password,username', (find['password'], find['username']))
result = pdb.execute("create database `" + find['name'] + "`")
if "using password:" in str(result):
return -1
if "Connection refused" in str(result):
return -1
password = find['password']
__createUser(find['name'], find['username'], password, find['accept'])
return 1
6 years ago
def syncToDatabases():
6 years ago
args = getArgs()
6 years ago
data = checkArgs(args, ['type', 'ids'])
6 years ago
if not data[0]:
return data[1]
pdb = pMysqlDb()
result = pdb.execute("show databases")
isError = isSqlError(result)
if isError:
return isError
stype = int(args['type'])
psdb = pSqliteDb('databases')
n = 0
6 years ago
6 years ago
if stype == 0:
6 years ago
data = psdb.field('id,name,username,password,accept').select()
6 years ago
for value in data:
result = toDbBase(value)
if result == 1:
n += 1
else:
6 years ago
data = json.loads(args['ids'])
for value in data:
find = psdb.where("id=?", (value,)).field(
'id,name,username,password,accept').find()
# print find
result = toDbBase(find)
if result == 1:
n += 1
msg = mw.getInfo('本次共同步了{1}个数据库!', (str(n),))
return mw.returnJson(True, msg)
6 years ago
6 years ago
def setRootPwd():
args = getArgs()
data = checkArgs(args, ['password'])
if not data[0]:
return data[1]
6 years ago
password = args['password']
try:
pdb = pMysqlDb()
result = pdb.query("show databases")
isError = isSqlError(result)
if isError != None:
return isError
m_version = mw.readFile(getServerDir() + '/version.pl')
6 years ago
if m_version.find('5.7') == 0 or m_version.find('8.0') == 0:
pdb.execute(
"UPDATE mysql.user SET authentication_string='' WHERE user='root'")
pdb.execute(
"ALTER USER 'root'@'localhost' IDENTIFIED BY '%s'" % password)
pdb.execute(
"ALTER USER 'root'@'127.0.0.1' IDENTIFIED BY '%s'" % password)
else:
result = pdb.execute(
"update mysql.user set Password=password('" + password + "') where User='root'")
pdb.execute("flush privileges")
pSqliteDb('config').where('id=?', (1,)).save('mysql_root', (password,))
return mw.returnJson(True, '数据库root密码修改成功!')
6 years ago
except Exception as ex:
return mw.returnJson(False, '修改错误:' + str(ex))
6 years ago
6 years ago
def setUserPwd():
args = getArgs()
data = checkArgs(args, ['password', 'name'])
if not data[0]:
return data[1]
newpassword = args['password']
username = args['name']
id = args['id']
try:
pdb = pMysqlDb()
psdb = pSqliteDb('databases')
name = psdb.where('id=?', (id,)).getField('name')
m_version = mw.readFile(getServerDir() + '/version.pl')
6 years ago
if m_version.find('5.7') == 0 or m_version.find('8.0') == 0:
tmp = pdb.query(
"select Host from mysql.user where User='" + name + "' AND Host!='localhost'")
accept = mapToList(tmp)
pdb.execute(
"update mysql.user set authentication_string='' where User='" + username + "'")
result = pdb.execute(
"ALTER USER `%s`@`localhost` IDENTIFIED BY '%s'" % (username, newpassword))
for my_host in accept:
pdb.execute("ALTER USER `%s`@`%s` IDENTIFIED BY '%s'" % (
username, my_host[0], newpassword))
else:
result = pdb.execute("update mysql.user set Password=password('" +
newpassword + "') where User='" + username + "'")
isError = isSqlError(result)
if isError != None:
return isError
pdb.execute("flush privileges")
psdb.where("id=?", (id,)).setField('password', newpassword)
return mw.returnJson(True, mw.getInfo('修改数据库[{1}]密码成功!', (name,)))
6 years ago
except Exception as ex:
# print str(ex)
return mw.returnJson(False, mw.getInfo('修改数据库[{1}]密码失败!', (name,)))
6 years ago
def setDbPs():
6 years ago
args = getArgs()
data = checkArgs(args, ['id', 'name', 'ps'])
if not data[0]:
return data[1]
6 years ago
ps = args['ps']
sid = args['id']
name = args['name']
try:
psdb = pSqliteDb('databases')
psdb.where("id=?", (sid,)).setField('ps', ps)
return mw.returnJson(True, mw.getInfo('修改数据库[{1}]备注成功!', (name,)))
except Exception as e:
return mw.returnJson(True, mw.getInfo('修改数据库[{1}]备注失败!', (name,)))
def addDb():
args = getArgs()
6 years ago
data = checkArgs(args,
['password', 'name', 'codeing', 'db_user', 'dataAccess', 'ps'])
if not data[0]:
return data[1]
6 years ago
if not 'address' in args:
address = ''
else:
address = args['address'].strip()
dbname = args['name'].strip()
dbuser = args['db_user'].strip()
codeing = args['codeing'].strip()
password = args['password'].strip()
dataAccess = args['dataAccess'].strip()
6 years ago
ps = args['ps'].strip()
6 years ago
reg = "^[\w\.-]+$"
if not re.match(reg, args['name']):
return mw.returnJson(False, '数据库名称不能带有特殊符号!')
6 years ago
checks = ['root', 'mysql', 'test', 'sys', 'panel_logs']
if dbuser in checks or len(dbuser) < 1:
return mw.returnJson(False, '数据库用户名不合法!')
6 years ago
if dbname in checks or len(dbname) < 1:
return mw.returnJson(False, '数据库名称不合法!')
6 years ago
if len(password) < 1:
password = mw.md5(time.time())[0:8]
6 years ago
wheres = {
'utf8': 'utf8_general_ci',
'utf8mb4': 'utf8mb4_general_ci',
'gbk': 'gbk_chinese_ci',
'big5': 'big5_chinese_ci'
}
codeStr = wheres[codeing]
pdb = pMysqlDb()
psdb = pSqliteDb('databases')
if psdb.where("name=? or username=?", (dbname, dbuser)).count():
return mw.returnJson(False, '数据库已存在!')
6 years ago
result = pdb.execute("create database `" + dbname +
"` DEFAULT CHARACTER SET " + codeing + " COLLATE " + codeStr)
# print result
isError = isSqlError(result)
if isError != None:
return isError
pdb.execute("drop user '" + dbuser + "'@'localhost'")
for a in address.split(','):
pdb.execute("drop user '" + dbuser + "'@'" + a + "'")
__createUser(dbname, dbuser, password, address)
addTime = time.strftime('%Y-%m-%d %X', time.localtime())
psdb.add('pid,name,username,password,accept,ps,addtime',
6 years ago
(0, dbname, dbuser, password, address, ps, addTime))
return mw.returnJson(True, '添加成功!')
6 years ago
def delDb():
6 years ago
args = getArgs()
data = checkArgs(args, ['id', 'name'])
if not data[0]:
return data[1]
6 years ago
try:
6 years ago
id = args['id']
name = args['name']
psdb = pSqliteDb('databases')
pdb = pMysqlDb()
find = psdb.where("id=?", (id,)).field(
'id,pid,name,username,password,accept,ps,addtime').find()
accept = find['accept']
username = find['username']
# 删除MYSQL
result = pdb.execute("drop database `" + name + "`")
isError = isSqlError(result)
if isError != None:
return isError
users = pdb.query(
"select Host from mysql.user where User='" + username + "' AND Host!='localhost'")
pdb.execute("drop user '" + username + "'@'localhost'")
for us in users:
pdb.execute("drop user '" + username + "'@'" + us[0] + "'")
pdb.execute("flush privileges")
# 删除SQLITE
psdb.where("id=?", (id,)).delete()
return mw.returnJson(True, '删除成功!')
6 years ago
except Exception as ex:
return mw.returnJson(False, '删除失败!' + str(ex))
6 years ago
6 years ago
def getDbAccess():
args = getArgs()
data = checkArgs(args, ['username'])
if not data[0]:
return data[1]
username = args['username']
pdb = pMysqlDb()
users = pdb.query("select Host from mysql.user where User='" +
username + "' AND Host!='localhost'")
isError = isSqlError(users)
if isError != None:
return isError
users = mapToList(users)
if len(users) < 1:
return mw.returnJson(True, "127.0.0.1")
6 years ago
accs = []
for c in users:
accs.append(c[0])
userStr = ','.join(accs)
return mw.returnJson(True, userStr)
6 years ago
6 years ago
6 years ago
def toSize(size):
d = ('b', 'KB', 'MB', 'GB', 'TB')
s = d[0]
for b in d:
if size < 1024:
return str(size) + ' ' + b
size = size / 1024
s = b
6 years ago
_size = round(size, 2)
4 years ago
# print(size, _size)
6 years ago
return str(size) + ' ' + b
6 years ago
6 years ago
6 years ago
def setDbAccess():
args = getArgs()
data = checkArgs(args, ['username', 'access'])
if not data[0]:
return data[1]
name = args['username']
access = args['access']
pdb = pMysqlDb()
psdb = pSqliteDb('databases')
dbname = psdb.where('username=?', (name,)).getField('name')
4 years ago
if name == 'root':
password = pSqliteDb('config').where(
'id=?', (1,)).getField('mysql_root')
else:
password = psdb.where("username=?", (name,)).getField('password')
6 years ago
users = pdb.query("select Host from mysql.user where User='" +
name + "' AND Host!='localhost'")
for us in users:
pdb.execute("drop user '" + name + "'@'" + us[0] + "'")
__createUser(dbname, name, password, access)
6 years ago
psdb.where('username=?', (name,)).save('accept', (access,))
return mw.returnJson(True, '设置成功!')
6 years ago
6 years ago
def getDbInfo():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
db_name = args['name']
pdb = pMysqlDb()
# print 'show tables from `%s`' % db_name
table_res = pdb.query('show tables from `%s`' % db_name)
isError = isSqlError(table_res)
if isError != None:
return isError
tables = mapToList(table_res)
ret = {}
if type(tables) == list:
try:
data = mapToList(pdb.query(
"select sum(DATA_LENGTH)+sum(INDEX_LENGTH) from information_schema.tables where table_schema='%s'" % db_name))[0][0]
except:
data = 0
if not data:
data = 0
ret['data_size'] = mw.toSize(data)
6 years ago
# print ret
6 years ago
ret['database'] = db_name
ret3 = []
for i in tables:
if i == 1049:
return mw.returnJson(False, '指定数据库不存在!')
6 years ago
table = mapToList(
pdb.query("show table status from `%s` where name = '%s'" % (db_name, i[0])))
if not table:
continue
try:
ret2 = {}
ret2['type'] = table[0][1]
ret2['rows_count'] = table[0][4]
ret2['collation'] = table[0][14]
6 years ago
data_size = table[0][6] + table[0][8]
6 years ago
ret2['data_byte'] = data_size
ret2['data_size'] = mw.toSize(data_size)
6 years ago
ret2['table_name'] = i[0]
ret3.append(ret2)
except:
continue
ret['tables'] = (ret3)
return mw.getJson(ret)
6 years ago
def repairTable():
args = getArgs()
data = checkArgs(args, ['db_name', 'tables'])
if not data[0]:
return data[1]
db_name = args['db_name']
tables = json.loads(args['tables'])
pdb = pMysqlDb()
mysql_table = mapToList(pdb.query('show tables from `%s`' % db_name))
ret = []
if type(mysql_table) == list:
if len(mysql_table) > 0:
for i in mysql_table:
for i2 in tables:
if i2 == i[0]:
ret.append(i2)
if len(ret) > 0:
for i in ret:
pdb.execute('REPAIR TABLE `%s`.`%s`' % (db_name, i))
return mw.returnJson(True, "修复完成!")
return mw.returnJson(False, "修复失败!")
def optTable():
args = getArgs()
data = checkArgs(args, ['db_name', 'tables'])
if not data[0]:
return data[1]
db_name = args['db_name']
tables = json.loads(args['tables'])
pdb = pMysqlDb()
mysql_table = mapToList(pdb.query('show tables from `%s`' % db_name))
ret = []
if type(mysql_table) == list:
if len(mysql_table) > 0:
for i in mysql_table:
for i2 in tables:
if i2 == i[0]:
ret.append(i2)
if len(ret) > 0:
for i in ret:
pdb.execute('OPTIMIZE TABLE `%s`.`%s`' % (db_name, i))
return mw.returnJson(True, "优化成功!")
return mw.returnJson(False, "优化失败或者已经优化过了!")
def alterTable():
args = getArgs()
data = checkArgs(args, ['db_name', 'tables'])
if not data[0]:
return data[1]
db_name = args['db_name']
tables = json.loads(args['tables'])
table_type = args['table_type']
pdb = pMysqlDb()
mysql_table = mapToList(pdb.query('show tables from `%s`' % db_name))
ret = []
if type(mysql_table) == list:
if len(mysql_table) > 0:
for i in mysql_table:
for i2 in tables:
if i2 == i[0]:
ret.append(i2)
if len(ret) > 0:
for i in ret:
pdb.execute('alter table `%s`.`%s` ENGINE=`%s`' %
(db_name, i, table_type))
return mw.returnJson(True, "更改成功!")
return mw.returnJson(False, "更改失败!")
6 years ago
def getTotalStatistics():
st = status()
data = {}
3 years ago
isInstall = os.path.exists(getServerDir() + '/version.pl')
if st == 'start' and isInstall:
6 years ago
data['status'] = True
data['count'] = pSqliteDb('databases').count()
data['ver'] = mw.readFile(getServerDir() + '/version.pl').strip()
return mw.returnJson(True, 'ok', data)
6 years ago
else:
data['status'] = False
data['count'] = 0
return mw.returnJson(False, 'fail', data)
6 years ago
4 years ago
def findBinlogDoDb():
conf = getConf()
con = mw.readFile(conf)
4 years ago
rep = r"binlog-do-db\s*?=\s*?(.*)"
dodb = re.findall(rep, con, re.M)
return dodb
4 years ago
4 years ago
def findBinlogSlaveDoDb():
conf = getConf()
con = mw.readFile(conf)
rep = r"replicate-do-db\s*?=\s*?(.*)"
dodb = re.findall(rep, con, re.M)
return dodb
4 years ago
def getMasterDbList(version=''):
args = getArgs()
page = 1
page_size = 10
search = ''
data = {}
if 'page' in args:
page = int(args['page'])
if 'page_size' in args:
page_size = int(args['page_size'])
if 'search' in args:
search = args['search']
conn = pSqliteDb('databases')
limit = str((page - 1) * page_size) + ',' + str(page_size)
condition = ''
dodb = findBinlogDoDb()
data['dodb'] = dodb
4 years ago
slave_dodb = findBinlogSlaveDoDb()
4 years ago
if not search == '':
condition = "name like '%" + search + "%'"
field = 'id,pid,name,username,password,accept,ps,addtime'
clist = conn.where(condition, ()).field(
field).limit(limit).order('id desc').select()
count = conn.where(condition, ()).count()
4 years ago
for x in range(0, len(clist)):
4 years ago
if clist[x]['name'] in dodb:
clist[x]['master'] = 1
else:
clist[x]['master'] = 0
4 years ago
if clist[x]['name'] in slave_dodb:
clist[x]['slave'] = 1
else:
clist[x]['slave'] = 0
4 years ago
_page = {}
_page['count'] = count
_page['p'] = page
_page['row'] = page_size
_page['tojs'] = 'dbList'
data['page'] = mw.getPage(_page)
data['data'] = clist
return mw.getJson(data)
def setDbMaster(version):
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
conf = getConf()
con = mw.readFile(conf)
4 years ago
rep = r"(binlog-do-db\s*?=\s*?(.*))"
dodb = re.findall(rep, con, re.M)
4 years ago
4 years ago
isHas = False
4 years ago
for x in range(0, len(dodb)):
4 years ago
if dodb[x][1] == args['name']:
isHas = True
con = con.replace(dodb[x][0] + "\n", '')
mw.writeFile(conf, con)
if not isHas:
prefix = '#binlog-do-db'
con = con.replace(
prefix, prefix + "\nbinlog-do-db=" + args['name'])
4 years ago
mw.writeFile(conf, con)
restart(version)
4 years ago
time.sleep(4)
4 years ago
return mw.returnJson(True, '设置成功', [args, dodb])
4 years ago
def setDbSlave(version):
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
conf = getConf()
con = mw.readFile(conf)
rep = r"(replicate-do-db\s*?=\s*?(.*))"
dodb = re.findall(rep, con, re.M)
isHas = False
4 years ago
for x in range(0, len(dodb)):
4 years ago
if dodb[x][1] == args['name']:
isHas = True
con = con.replace(dodb[x][0] + "\n", '')
mw.writeFile(conf, con)
if not isHas:
prefix = '#replicate-do-db'
con = con.replace(
prefix, prefix + "\nreplicate-do-db=" + args['name'])
mw.writeFile(conf, con)
restart(version)
time.sleep(4)
return mw.returnJson(True, '设置成功', [args, dodb])
4 years ago
def getMasterStatus(version=''):
4 years ago
if status(version) == 'stop':
4 years ago
return mw.returnJson(false, 'MySQL未启动,或正在启动中...!', [])
4 years ago
4 years ago
conf = getConf()
con = mw.readFile(conf)
master_status = False
if con.find('#log-bin') == -1 and con.find('log-bin') > 1:
4 years ago
dodb = findBinlogDoDb()
if len(dodb) > 0:
4 years ago
master_status = True
data = {}
data['status'] = master_status
db = pMysqlDb()
dlist = db.query('show slave status')
4 years ago
#print(dlist, len(dlist))
4 years ago
if len(dlist) > 0 and (dlist[0][10] == 'Yes' or dlist[0][11] == 'Yes'):
data['slave_status'] = True
return mw.returnJson(master_status, '设置成功', data)
4 years ago
def setMasterStatus(version=''):
conf = getConf()
con = mw.readFile(conf)
4 years ago
if con.find('#log-bin') != -1:
return mw.returnJson(False, '必须开启二进制日志')
4 years ago
sign = 'mdserver_ms_open'
dodb = findBinlogDoDb()
if not sign in dodb:
prefix = '#binlog-do-db'
con = con.replace(prefix, prefix + "\nbinlog-do-db=" + sign)
mw.writeFile(conf, con)
else:
con = con.replace("binlog-do-db=" + sign + "\n", '')
rep = r"(binlog-do-db\s*?=\s*?(.*))"
dodb = re.findall(rep, con, re.M)
4 years ago
for x in range(0, len(dodb)):
4 years ago
con = con.replace(dodb[x][0] + "\n", '')
mw.writeFile(conf, con)
restart(version)
4 years ago
return mw.returnJson(True, '设置成功')
4 years ago
def getMasterRepSlaveList(version=''):
args = getArgs()
page = 1
page_size = 10
search = ''
data = {}
if 'page' in args:
page = int(args['page'])
if 'page_size' in args:
page_size = int(args['page_size'])
if 'search' in args:
search = args['search']
conn = pSqliteDb('master_replication_user')
limit = str((page - 1) * page_size) + ',' + str(page_size)
condition = ''
if not search == '':
condition = "name like '%" + search + "%'"
field = 'id,username,password,accept,ps,addtime'
clist = conn.where(condition, ()).field(
field).limit(limit).order('id desc').select()
count = conn.where(condition, ()).count()
_page = {}
_page['count'] = count
_page['p'] = page
_page['row'] = page_size
_page['tojs'] = 'getMasterRepSlaveList'
data['page'] = mw.getPage(_page)
data['data'] = clist
return mw.getJson(data)
def addMasterRepSlaveUser(version=''):
args = getArgs()
data = checkArgs(args,
['username', 'password'])
if not data[0]:
return data[1]
if not 'address' in args:
address = ''
else:
address = args['address'].strip()
username = args['username'].strip()
password = args['password'].strip()
# ps = args['ps'].strip()
# address = args['address'].strip()
# dataAccess = args['dataAccess'].strip()
reg = "^[\w\.-]+$"
if not re.match(reg, username):
return mw.returnJson(False, '用户名不能带有特殊符号!')
checks = ['root', 'mysql', 'test', 'sys', 'panel_logs']
if username in checks or len(username) < 1:
return mw.returnJson(False, '用户名不合法!')
if password in checks or len(password) < 1:
return mw.returnJson(False, '密码不合法!')
if len(password) < 1:
password = mw.md5(time.time())[0:8]
pdb = pMysqlDb()
psdb = pSqliteDb('master_replication_user')
if psdb.where("username=?", (username)).count():
return mw.returnJson(False, '用户已存在!')
result = pdb.execute("GRANT REPLICATION SLAVE ON *.* TO '" +
4 years ago
username + "'@'%' identified by '" + password + "';FLUSH PRIVILEGES;")
4 years ago
# print result
isError = isSqlError(result)
if isError != None:
return isError
addTime = time.strftime('%Y-%m-%d %X', time.localtime())
psdb.add('username,password,accept,ps,addtime',
(username, password, '%', '', addTime))
return mw.returnJson(True, '添加成功!')
def getMasterRepSlaveUserCmd(version):
args = getArgs()
data = checkArgs(args, ['username', 'db'])
4 years ago
if not data[0]:
return data[1]
psdb = pSqliteDb('master_replication_user')
f = 'username,password'
if args['username'] == '':
count = psdb.count()
if count == 0:
return mw.returnJson(False, '请添加同步账户!')
clist = psdb.field(f).limit('1').order('id desc').select()
else:
clist = psdb.field(f).where("username=?", (args['username'],)).limit(
'1').order('id desc').select()
4 years ago
ip = mw.getLocalIp()
port = getMyPort()
db = pMysqlDb()
tmp = db.query('show master status')
4 years ago
if len(tmp) == 0:
return mw.returnJson(False, '未开启!')
4 years ago
sql = "CHANGE MASTER TO MASTER_HOST='" + ip + "', MASTER_PORT=" + port + ", MASTER_USER='" + \
4 years ago
clist[0]['username'] + "', MASTER_PASSWORD='" + \
4 years ago
clist[0]['password'] + \
"', MASTER_LOG_FILE='" + tmp[0][0] + \
"',MASTER_LOG_POS=" + str(tmp[0][1]) + ""
# if args['db'] != '':
# replicate-do-table
return mw.returnJson(True, 'OK!', sql)
4 years ago
def delMasterRepSlaveUser(version=''):
args = getArgs()
data = checkArgs(args, ['username'])
if not data[0]:
return data[1]
pdb = pMysqlDb()
psdb = pSqliteDb('master_replication_user')
pdb.execute("drop user '" + args['username'] + "'@'%'")
psdb.where("username=?", (args['username'],)).delete()
return mw.returnJson(True, '删除成功!')
4 years ago
def updateMasterRepSlaveUser(version=''):
args = getArgs()
data = checkArgs(args, ['username', 'password'])
if not data[0]:
return data[1]
pdb = pMysqlDb()
psdb = pSqliteDb('master_replication_user')
pdb.execute("drop user '" + args['username'] + "'@'%'")
pdb.execute("GRANT REPLICATION SLAVE ON *.* TO '" +
args['username'] + "'@'%' identified by '" + args['password'] + "'")
psdb.where("username=?", (args['username'],)).save(
'password', args['password'])
return mw.returnJson(True, '更新成功!')
def getSlaveList(version=''):
db = pMysqlDb()
dlist = db.query('show slave status')
# print(dlist)
ret = []
4 years ago
for x in range(0, len(dlist)):
tmp = {}
tmp['Master_User'] = dlist[x][2]
tmp['Master_Host'] = dlist[x][1]
tmp['Master_Port'] = dlist[x][3]
tmp['Master_Log_File'] = dlist[x][5]
tmp['Slave_IO_Running'] = dlist[x][10]
tmp['Slave_SQL_Running'] = dlist[x][11]
ret.append(tmp)
data = {}
data['data'] = ret
return mw.getJson(data)
def setSlaveStatus(version=''):
db = pMysqlDb()
dlist = db.query('show slave status')
4 years ago
if len(dlist) == 0:
return mw.returnJson(False, '需要手动添加主服务同步命令!')
4 years ago
if len(dlist) > 0 and (dlist[0][10] == 'Yes' or dlist[0][11] == 'Yes'):
db.query('stop slave')
else:
db.query('start slave')
4 years ago
return mw.returnJson(True, '设置成功!')
4 years ago
def deleteSlave(version=''):
db = pMysqlDb()
dlist = db.query('stop slave;reset slave all')
return mw.returnJson(True, '删除成功!')
4 years ago
4 years ago
def dumpMysqlData(version):
4 years ago
args = getArgs()
data = checkArgs(args, ['db'])
if not data[0]:
return data[1]
4 years ago
4 years ago
pwd = pSqliteDb('config').where('id=?', (1,)).getField('mysql_root')
4 years ago
if args['db'] == 'all' or args['db'] == 'ALL':
dlist = findBinlogDoDb()
cmd = getServerDir() + "/bin/mysqldump -uroot -p" + \
pwd + " --databases " + ' '.join(dlist) + \
" > /tmp/dump.sql"
else:
cmd = getServerDir() + "/bin/mysqldump -uroot -p" + pwd + \
" --databases " + args['db'] + " > /tmp/dump.sql"
4 years ago
ret = mw.execShell(cmd)
if ret[0] == '':
return 'ok'
return 'fail'
4 years ago
from threading import Thread
from time import sleep
4 years ago
4 years ago
def mw_async(f):
4 years ago
def wrapper(*args, **kwargs):
thr = Thread(target=f, args=args, kwargs=kwargs)
thr.start()
return wrapper
4 years ago
4 years ago
def doFullSync():
args = getArgs()
data = checkArgs(args, ['db'])
if not data[0]:
return data[1]
status_data = {}
status_data['progress'] = 5
4 years ago
4 years ago
db = pMysqlDb()
4 years ago
dlist = db.query('show slave status')
if len(dlist) == 0:
status_data['code'] = -1
status_data['msg'] = '没有启动...'
ip = dlist[0][1]
print(ip)
4 years ago
status_file = '/tmp/db_async_status.txt'
4 years ago
status_data['code'] = 0
status_data['msg'] = '运行中...'
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
import paramiko
paramiko.util.log_to_file('paramiko.log')
ssh = paramiko.SSHClient()
4 years ago
SSH_PRIVATE_KEY = '/root/.ssh/id_rsa'
if mw.getOs() == 'darwin':
user = mw.execShell(
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
4 years ago
SSH_PRIVATE_KEY = '/Users/' + user + '/.ssh/id_rsa'
4 years ago
4 years ago
print(SSH_PRIVATE_KEY)
4 years ago
if not os.path.exists(SSH_PRIVATE_KEY):
status_data['code'] = 0
status_data['msg'] = '需要配置免登录...'
mw.writeFile(status_file, json.dumps(status_data))
return
try:
key = paramiko.RSAKey.from_private_key_file(SSH_PRIVATE_KEY)
# ssh.load_system_host_keys()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname=ip, port=22, username='root', pkey=key)
except Exception as e:
status_data['code'] = 0
status_data['msg'] = '需要配置免登录....'
mw.writeFile(status_file, json.dumps(status_data))
return
4 years ago
cmd = "cd /www/server/mdserver-web && python /www/server/mdserver-web/plugins/mysql/index.py dump_mysql_data {\"db\":'" + args[
'db'] + "'}"
4 years ago
stdin, stdout, stderr = ssh.exec_command(cmd)
result = stdout.read()
result_err = stderr.read()
4 years ago
if result == 'ok':
4 years ago
status_data['code'] = 1
status_data['msg'] = '主服务器备份完成...'
status_data['progress'] = 30
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
4 years ago
r = mw.execShell('scp root@' + ip + ':/tmp/dump.sql /tmp')
4 years ago
if r[0] == '':
4 years ago
status_data['code'] = 2
status_data['msg'] = '数据同步本地完成...'
status_data['progress'] = 40
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
4 years ago
cmd = 'cd /www/server/mdserver-web && python /www/server/mdserver-web/plugins/mysql/index.py get_master_rep_slave_user_cmd {"username":"","db":""}'
stdin, stdout, stderr = ssh.exec_command(cmd)
result = stdout.read()
result_err = stderr.read()
cmd_data = json.loads(result)
db.query('stop slave')
4 years ago
status_data['code'] = 3
status_data['msg'] = '停止从库完成...'
status_data['progress'] = 45
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
4 years ago
dlist = db.query(cmd_data['data'])
4 years ago
status_data['code'] = 4
status_data['msg'] = '刷新库信息完成...'
status_data['progress'] = 50
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
4 years ago
pwd = pSqliteDb('config').where('id=?', (1,)).getField('mysql_root')
4 years ago
cmd = getServerDir() + "/bin/mysql -uroot -p" + pwd + " < /tmp/dump.sql"
4 years ago
print(mw.execShell(cmd))
4 years ago
status_data['code'] = 5
status_data['msg'] = '同步数据完成...'
status_data['progress'] = 90
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
db.query('start slave')
4 years ago
status_data['code'] = 6
status_data['msg'] = '从库重启完成...'
status_data['progress'] = 100
mw.writeFile(status_file, json.dumps(status_data))
4 years ago
return True
def fullSync(version=''):
args = getArgs()
4 years ago
data = checkArgs(args, ['db', 'begin'])
4 years ago
if not data[0]:
return data[1]
4 years ago
status_file = '/tmp/db_async_status.txt'
if args['begin'] == '1':
4 years ago
cmd = 'cd ' + mw.getRunDir() + ' && python ' + \
4 years ago
getPluginDir() + \
'/index.py do_full_sync {"db":"' + args['db'] + '"} &'
4 years ago
mw.execShell(cmd)
return json.dumps({'code': 0, 'msg': '同步数据中!', 'progress': 0})
4 years ago
if os.path.exists(status_file):
c = mw.readFile(status_file)
d = json.loads(c)
4 years ago
4 years ago
if d['code'] == 6:
4 years ago
os.remove(status_file)
4 years ago
return c
4 years ago
4 years ago
return json.dumps({'code': 0, 'msg': '点击开始,开始同步!', 'progress': 0})
4 years ago
7 years ago
if __name__ == "__main__":
func = sys.argv[1]
4 years ago
version = "5.6"
if (len(sys.argv) > 2):
version = sys.argv[2]
6 years ago
if func == 'status':
4 years ago
print(status(version))
7 years ago
elif func == 'start':
4 years ago
print(start(version))
7 years ago
elif func == 'stop':
3 years ago
print(stop(version))
7 years ago
elif func == 'restart':
4 years ago
print(restart(version))
7 years ago
elif func == 'reload':
4 years ago
print(reload(version))
6 years ago
elif func == 'initd_status':
4 years ago
print(initdStatus())
6 years ago
elif func == 'initd_install':
4 years ago
print(initdInstall())
6 years ago
elif func == 'initd_uninstall':
4 years ago
print(initdUinstall())
6 years ago
elif func == 'run_info':
4 years ago
print(runInfo())
6 years ago
elif func == 'db_status':
4 years ago
print(myDbStatus())
6 years ago
elif func == 'set_db_status':
4 years ago
print(setDbStatus())
6 years ago
elif func == 'conf':
4 years ago
print(getConf())
6 years ago
elif func == 'bin_log':
4 years ago
print(binLog())
6 years ago
elif func == 'error_log':
4 years ago
print(getErrorLog())
6 years ago
elif func == 'show_log':
4 years ago
print(getShowLogFile())
elif func == 'my_db_pos':
4 years ago
print(getMyDbPos())
elif func == 'set_db_pos':
4 years ago
print(setMyDbPos())
6 years ago
elif func == 'my_port':
4 years ago
print(getMyPort())
6 years ago
elif func == 'set_my_port':
4 years ago
print(setMyPort())
6 years ago
elif func == 'init_pwd':
4 years ago
print(initMysqlPwd())
6 years ago
elif func == 'get_db_list':
4 years ago
print(getDbList())
4 years ago
elif func == 'set_db_backup':
print(setDbBackup())
4 years ago
elif func == 'import_db_backup':
print(importDbBackup())
4 years ago
elif func == 'delete_db_backup':
print(deleteDbBackup())
4 years ago
elif func == 'get_db_backup_list':
print(getDbBackupList())
6 years ago
elif func == 'add_db':
4 years ago
print(addDb())
6 years ago
elif func == 'del_db':
4 years ago
print(delDb())
6 years ago
elif func == 'sync_get_databases':
4 years ago
print(syncGetDatabases())
6 years ago
elif func == 'sync_to_databases':
4 years ago
print(syncToDatabases())
6 years ago
elif func == 'set_root_pwd':
4 years ago
print(setRootPwd())
6 years ago
elif func == 'set_user_pwd':
4 years ago
print(setUserPwd())
6 years ago
elif func == 'get_db_access':
4 years ago
print(getDbAccess())
6 years ago
elif func == 'set_db_access':
4 years ago
print(setDbAccess())
elif func == 'set_db_ps':
4 years ago
print(setDbPs())
6 years ago
elif func == 'get_db_info':
4 years ago
print(getDbInfo())
elif func == 'repair_table':
4 years ago
print(repairTable())
elif func == 'opt_table':
4 years ago
print(optTable())
elif func == 'alter_table':
4 years ago
print(alterTable())
6 years ago
elif func == 'get_total_statistics':
4 years ago
print(getTotalStatistics())
4 years ago
elif func == 'get_masterdb_list':
print(getMasterDbList(version))
4 years ago
elif func == 'get_master_status':
print(getMasterStatus(version))
elif func == 'set_master_status':
print(setMasterStatus(version))
4 years ago
elif func == 'set_db_master':
print(setDbMaster(version))
4 years ago
elif func == 'set_db_slave':
print(setDbSlave(version))
4 years ago
elif func == 'get_master_rep_slave_list':
print(getMasterRepSlaveList(version))
elif func == 'add_master_rep_slave_user':
print(addMasterRepSlaveUser(version))
elif func == 'del_master_rep_slave_user':
print(delMasterRepSlaveUser(version))
4 years ago
elif func == 'update_master_rep_slave_user':
print(updateMasterRepSlaveUser(version))
4 years ago
elif func == 'get_master_rep_slave_user_cmd':
print(getMasterRepSlaveUserCmd(version))
elif func == 'get_slave_list':
print(getSlaveList(version))
elif func == 'set_slave_status':
print(setSlaveStatus(version))
4 years ago
elif func == 'delete_slave':
print(deleteSlave(version))
4 years ago
elif func == 'full_sync':
4 years ago
print(fullSync(version))
4 years ago
elif func == 'do_full_sync':
print(doFullSync())
4 years ago
elif func == 'dump_mysql_data':
print(dumpMysqlData(version))
6 years ago
else:
4 years ago
print('error')