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/postgresql/index.py

1177 lines
35 KiB

3 years ago
# coding:utf-8
import sys
import io
import os
import time
import subprocess
import re
import json
# reload(sys)
# sys.setdefaultencoding('utf-8')
sys.path.append(os.getcwd() + "/class/core")
import mw
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)
app_debug = False
if mw.isAppleSystem():
app_debug = True
def getPluginName():
return 'postgresql'
def getPluginDir():
return mw.getPluginDir() + '/' + getPluginName()
def getServerDir():
return mw.getServerDir() + '/' + getPluginName()
def getInitDFile():
if app_debug:
return '/tmp/' + getPluginName()
return '/etc/init.d/' + getPluginName()
def getArgs():
args = sys.argv[2:]
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
3 years ago
def getBackupDir():
bk_path = mw.getBackupDir() + "/pg"
if not os.path.isdir(bk_path):
mw.execShell("mkdir -p {}/upload".format(bk_path))
bk_path_upload = bk_path + "/upload"
return bk_path_upload
3 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'))
def getConf():
path = getServerDir() + '/data/postgresql.conf'
return path
3 years ago
def configTpl():
clist = []
app_dir = getServerDir()
clist.append(app_dir + "/data/postgresql.conf")
clist.append(app_dir + "/data/pg_hba.conf")
return mw.getJson(clist)
3 years ago
def pgHbaConf():
return getServerDir() + "/data/pg_hba.conf"
3 years ago
def readConfigTpl():
args = getArgs()
data = checkArgs(args, ['file'])
if not data[0]:
return data[1]
content = mw.readFile(args['file'])
return mw.returnJson(True, 'ok', content)
3 years ago
def getDbPort():
file = getConf()
content = mw.readFile(file)
3 years ago
rep = 'port\s*=\s*(\d*)?'
3 years ago
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
def getSocketFile():
file = getConf()
content = mw.readFile(file)
rep = 'socket\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
def getInitdTpl(version=''):
path = getPluginDir() + '/init.d/postgresql.tpl'
if not os.path.exists(path):
path = getPluginDir() + '/init.d/postgresql.tpl'
return path
def contentReplace(content):
service_path = mw.getServerDir()
content = content.replace('{$ROOT_PATH}', mw.getRootDir())
content = content.replace('{$SERVER_PATH}', service_path)
content = content.replace('{$APP_PATH}', service_path + '/postgresql')
return content
def pSqliteDb(dbname='databases'):
file = getServerDir() + '/pgsql.db'
name = 'pgsql'
if not os.path.exists(file):
conn = mw.M(dbname).dbPos(getServerDir(), name)
csql = mw.readFile(getPluginDir() + '/conf/pgsql.sql')
csql_list = csql.split(';')
for index in range(len(csql_list)):
conn.execute(csql_list[index], ())
else:
# 现有run
# 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)
return conn
3 years ago
def pgDb():
sys.path.append(getPluginDir() + "/class")
import pg
db = pg.ORM()
3 years ago
db.setPort(getDbPort())
3 years ago
# db.setSocket(getSocketFile())
db.setPwd(pSqliteDb('config').where('id=?', (1,)).getField('pg_root'))
3 years ago
return db
def initDreplace(version=''):
3 years ago
conf_dir = getServerDir()
3 years ago
conf_list = [
3 years ago
conf_dir + "/logs",
conf_dir + "/tmp",
3 years ago
]
3 years ago
for c in conf_list:
if not os.path.exists(c):
os.mkdir(c)
3 years ago
3 years ago
init_pl = conf_dir + "/init.pl"
if not os.path.exists(init_pl):
3 years ago
mw.writeFile(init_pl, 'ok')
3 years ago
pg_conf = conf_dir + '/data/postgresql.conf'
tpl = getPluginDir() + '/conf/postgresql.conf'
content = mw.readFile(tpl)
content = contentReplace(content)
mw.writeFile(pg_conf, content)
3 years ago
3 years ago
logfile = runLog()
if not os.path.exists(logfile):
mw.writeFile(logfile, '')
3 years ago
# systemd
system_dir = mw.systemdCfgDir()
service = system_dir + '/postgresql.service'
if os.path.exists(system_dir) and not os.path.exists(service):
tpl = getPluginDir() + '/init.d/postgresql.service.tpl'
service_path = mw.getServerDir()
content = mw.readFile(tpl)
3 years ago
content = contentReplace(content)
3 years ago
mw.writeFile(service, content)
mw.execShell('systemctl daemon-reload')
if not mw.isAppleSystem():
mw.execShell('chown -R postgresql:postgresql ' + getServerDir())
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):
3 years ago
tpl = getInitdTpl(version)
content = mw.readFile(tpl)
3 years ago
content = contentReplace(content)
mw.writeFile(file_bin, content)
mw.execShell('chmod +x ' + file_bin)
return file_bin
def status(version=''):
data = mw.execShell(
"ps -ef|grep postgres |grep -v grep | grep -v python | grep -v mdserver-web | awk '{print $2}'")
if data[0] == '':
return 'stop'
return 'start'
def pGetDbUser():
if mw.isAppleSystem():
user = mw.execShell(
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
return user
return 'postgresql'
def initPgData():
3 years ago
serverdir = getServerDir()
3 years ago
if not os.path.exists(serverdir + '/data'):
3 years ago
cmd = serverdir + '/bin/initdb -D ' + serverdir + "/data"
if not mw.isAppleSystem():
cmd = "echo \"" + serverdir + "/bin/initdb -D " + \
serverdir + "/data\" | su - postgresql"
# print(cmd)
3 years ago
mw.execShell(cmd)
return False
return True
def initPgPwd():
serverdir = getServerDir()
pwd = mw.getRandomString(16)
3 years ago
cmd_pass = "echo \"create user postgres with superuser password '" + pwd + "'\" | "
3 years ago
cmd_pass = cmd_pass + serverdir + '/bin/psql -d postgres'
3 years ago
data = mw.execShell(cmd_pass)
3 years ago
# print(cmd_pass)
# print(data)
3 years ago
3 years ago
pSqliteDb('config').where('id=?', (1,)).save('pg_root', (pwd,))
3 years ago
return True
3 years ago
def pgOp(version, method):
3 years ago
# import commands
init_file = initDreplace()
cmd = init_file + ' ' + method
3 years ago
# print(cmd)
3 years ago
try:
isInited = initPgData()
if not isInited:
if mw.isAppleSystem():
cmd_init_start = init_file + ' start'
subprocess.Popen(cmd_init_start, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
time.sleep(6)
else:
mw.execShell('systemctl start postgresql')
initPgPwd()
if mw.isAppleSystem():
cmd_init_stop = init_file + ' stop'
subprocess.Popen(cmd_init_stop, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
time.sleep(3)
else:
mw.execShell('systemctl stop postgresql')
if mw.isAppleSystem():
sub = subprocess.Popen(cmd, stdout=subprocess.PIPE, shell=True,
bufsize=4096, stderr=subprocess.PIPE)
sub.wait(5)
else:
mw.execShell('systemctl ' + method + ' postgresql')
return 'ok'
except Exception as e:
3 years ago
# raise
return method + ":" + str(e)
3 years ago
def appCMD(version, action):
3 years ago
return pgOp(version, action)
3 years ago
def start(version=''):
return appCMD(version, 'start')
def stop(version=''):
return appCMD(version, 'stop')
def restart(version=''):
return appCMD(version, 'restart')
def reload(version=''):
3 years ago
logfile = runLog()
3 years ago
if os.path.exists(logfile):
3 years ago
mw.writeFile(logfile, '')
3 years ago
return appCMD(version, 'reload')
def initdStatus():
if mw.isAppleSystem():
return "Apple Computer does not support"
3 years ago
shell_cmd = 'systemctl status postgresql | grep loaded | grep "enabled;"'
3 years ago
data = mw.execShell(shell_cmd)
if data[0] == '':
return 'fail'
return 'ok'
def initdInstall():
if mw.isAppleSystem():
return "Apple Computer does not support"
3 years ago
mw.execShell('systemctl enable postgresql')
3 years ago
return 'ok'
def initdUinstall():
if mw.isAppleSystem():
return "Apple Computer does not support"
3 years ago
mw.execShell('systemctl disable postgresql')
3 years ago
return 'ok'
def getMyDbPos():
file = getConf()
content = mw.readFile(file)
rep = 'datadir\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
3 years ago
def setPgDbPos():
3 years ago
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 + '/')
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, '文件迁移失败!')
3 years ago
def getPgPort():
3 years ago
file = getConf()
content = mw.readFile(file)
rep = 'port\s*=\s*(.*)'
tmp = re.search(rep, content)
return tmp.groups()[0].strip()
3 years ago
def setPgPort():
3 years ago
args = getArgs()
data = checkArgs(args, ['port'])
if not data[0]:
return data[1]
port = args['port']
file = getConf()
content = mw.readFile(file)
rep = "port\s*=\s*([0-9]+)\s*\n"
content = re.sub(rep, 'port = ' + port + '\n', content)
mw.writeFile(file, content)
restart()
return mw.returnJson(True, '编辑成功!')
def runInfo():
if status(version) == 'stop':
return mw.returnJson(False, 'PG未启动', [])
3 years ago
db = pgDb()
# data = db.query('show global status')
data_directory = getServerDir() + "/data"
port = getPgPort()
3 years ago
result = {}
3 years ago
result['uptime'] = mw.execShell(
'''cat {}/postmaster.pid |sed -n 3p '''.format(data_directory))[0]
timestamp = result['uptime']
time_local = time.localtime(int(timestamp))
dt = time.strftime("%Y-%m-%d %H:%M:%S", time_local)
result['uptime'] = dt
result['progress_num'] = mw.execShell(
"ps -ef |grep postgres |wc -l")[0].strip()
result['pid'] = mw.execShell(
'''cat {}/postmaster.pid |sed -n 1p '''.format(data_directory))[0].strip()
res = db.query(
'SELECT count(*) FROM pg_stat_activity WHERE NOT pid=pg_backend_pid()')
result['connections'] = res[0][0]
res = db.query("select pg_size_pretty(pg_database_size('postgres'))")
result['pg_size'] = res[0][0]
result['pg_mem'] = mw.execShell(
'''cat /proc/%s/status|grep VmRSS|awk -F: '{print $2}' ''' % (result['pid']))[0]
result['pg_vm_lock'] = mw.execShell(
'''cat /proc/%s/status|grep VmLck|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_high'] = mw.execShell(
'''cat /proc/%s/status|grep VmHWM|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_data_size'] = mw.execShell(
'''cat /proc/%s/status|grep VmData|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_sk_size'] = mw.execShell(
'''cat /proc/%s/status|grep VmStk|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_code_size'] = mw.execShell(
'''cat /proc/%s/status|grep VmExe|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_lib_size'] = mw.execShell(
'''cat /proc/%s/status|grep VmLib|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_swap_size'] = mw.execShell(
'''cat /proc/%s/status|grep VmSwap|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_vm_page_size'] = mw.execShell(
'''cat /proc/%s/status|grep VmPTE|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
result['pg_sigq'] = mw.execShell(
'''cat /proc/%s/status|grep SigQ|awk -F: '{print $2}' ''' % (result['pid'].strip()))[0]
3 years ago
return mw.getJson(result)
3 years ago
def runLog():
return getServerDir() + "/logs/server.log"
3 years ago
def getSlowLog():
# pgsql慢日志查询
return getServerDir() + "/logs/" + time.strftime("postgresql-%Y-%m-%d.log")
3 years ago
def getUnit(args):
unit = ''
if "GB" in args:
unit = "GB"
elif "MB" in args:
unit = "MB"
elif "KB" in args:
unit = "KB"
elif "kB" in args:
unit = "kB"
return unit
def pgDbStatus():
data_directory = getServerDir() + "/data"
data = {}
shared_buffers, work_mem, effective_cache_size, maintence_work_mem, max_connections, temp_buffers, max_prepared_transactions, max_stack_depth, bgwriter_lru_maxpages, max_worker_processes, listen_addresses = '', '', '', '', '', '', '', '', '', '', ''
with open("{}/postgresql.conf".format(data_directory)) as f:
for i in f:
if i.strip().startswith("shared_buffers"):
shared_buffers = i.split("=")[1]
elif i.strip().startswith("#shared_buffers"):
shared_buffers = i.split("=")[1]
shared_buffers_num = re.match(
r'\d+', shared_buffers.strip()).group() if re.match(r'\d+', shared_buffers.strip()) else ""
data['shared_buffers'] = [shared_buffers_num, "MB",
3 years ago
"PG通过shared_buffers和内核和磁盘打交道,通常设置为实际内存的10%."]
3 years ago
if i.strip().startswith("work_mem"):
work_mem = i.split("=")[1]
elif i.strip().startswith("#work_mem"):
work_mem = i.split("=")[1]
work_mem_num = re.match(
r'\d+', work_mem.strip()).group() if re.match(r'\d+', work_mem.strip()) else ""
data['work_mem'] = [work_mem_num, "MB",
3 years ago
"增加work_mem有助于提高排序的速度。通常设置为实际RAM的2% -4%."]
3 years ago
if i.strip().startswith("effective_cache_size"):
effective_cache_size = i.split("=")[1]
elif i.strip().startswith("#effective_cache_size"):
effective_cache_size = i.split("=")[1]
effective_cache_size_num = re.match(r'\d+', effective_cache_size.strip(
)).group() if re.match(r'\d+', effective_cache_size.strip()) else ""
data['effective_cache_size'] = [effective_cache_size_num,
3 years ago
"GB", "PG能够使用的最大缓存,比如4G的内存,可以设置为3GB."]
3 years ago
if i.strip().startswith("temp_buffers "):
temp_buffers = i.split("=")[1]
elif i.strip().startswith("#temp_buffers "):
temp_buffers = i.split("=")[1]
temp_buffers_num = re.match(
r'\d+', temp_buffers.strip()).group() if re.match(r'\d+', temp_buffers.strip()) else ""
data['temp_buffers'] = [temp_buffers_num, "MB",
"设置每个数据库会话使用的临时缓冲区的最大数目,默认是8MB"]
if i.strip().startswith("max_connections"):
max_connections = i.split("=")[1]
elif i.strip().startswith("#max_connections"):
max_connections = i.split("=")[1]
max_connections_num = re.match(
r'\d+', max_connections.strip()).group() if re.match(r'\d+', max_connections.strip()) else ""
data['max_connections'] = [max_connections_num,
getUnit(max_connections), "最大连接数"]
if i.strip().startswith("max_prepared_transactions"):
max_prepared_transactions = i.split("=")[1]
elif i.strip().startswith("#max_prepared_transactions"):
max_prepared_transactions = i.split("=")[1]
max_prepared_transactions_num = re.match(r'\d+', max_prepared_transactions.strip(
)).group() if re.match(r'\d+', max_prepared_transactions.strip()) else ""
data['max_prepared_transactions'] = [max_prepared_transactions_num, getUnit(
max_prepared_transactions), "设置可以同时处于 prepared 状态的事务的最大数目"]
if i.strip().startswith("max_stack_depth "):
max_stack_depth = i.split("=")[1]
elif i.strip().startswith("#max_stack_depth "):
max_stack_depth = i.split("=")[1]
max_stack_depth_num = re.match(
r'\d+', max_stack_depth.strip()).group() if re.match(r'\d+', max_stack_depth.strip()) else ""
data['max_stack_depth'] = [max_stack_depth_num,
"MB", "指定服务器的执行堆栈的最大安全深度,默认是2MB"]
if i.strip().startswith("bgwriter_lru_maxpages "):
bgwriter_lru_maxpages = i.split("=")[1]
elif i.strip().startswith("#bgwriter_lru_maxpages "):
bgwriter_lru_maxpages = i.split("=")[1]
bgwriter_lru_maxpages_num = re.match(r'\d+', bgwriter_lru_maxpages.strip(
)).group() if re.match(r'\d+', bgwriter_lru_maxpages.strip()) else ""
data['bgwriter_lru_maxpages'] = [
bgwriter_lru_maxpages_num, "", "一个周期最多写多少脏页"]
if i.strip().startswith("max_worker_processes "):
max_worker_processes = i.split("=")[1]
elif i.strip().startswith("#max_worker_processes "):
max_worker_processes = i.split("=")[1]
max_worker_processes_num = re.match(r'\d+', max_worker_processes.strip(
)).group() if re.match(r'\d+', max_worker_processes.strip()) else ""
data['max_worker_processes'] = [max_worker_processes_num,
"", "如果要使用worker process, 最多可以允许fork 多少个worker进程."]
3 years ago
# if i.strip().startswith("listen_addresses"):
# listen_addresses = i.split("=")[1]
# elif i.strip().startswith("#listen_addresses"):
# listen_addresses = i.split("=")[1]
# listen_addresses = re.match(r"\'.*?\'", listen_addresses.strip()).group(
# ) if re.match(r"\'.*?\'", listen_addresses.strip()) else ""
# data['listen_addresses'] = [listen_addresses.replace(
# "'", '').replace("127.0.0.1", 'localhost'), "", "pgsql监听地址"]
3 years ago
# 返回数据到前端
data['status'] = True
return mw.getJson(data)
3 years ago
3 years ago
def sedConf(name, val):
path = getServerDir() + "/data/postgresql.conf"
content = ''
with open(path) as f:
for i in f:
if i.strip().startswith(name):
i = "{} = {} \n".format(name, val)
content += i
mw.writeFile(path, content)
return True
def pgSetDbStatus():
3 years ago
'''
3 years ago
保存pgsql性能调整信息
'''
3 years ago
args = getArgs()
3 years ago
data = checkArgs(args, ['shared_buffers', 'work_mem', 'effective_cache_size',
'temp_buffers', 'max_connections', 'max_prepared_transactions',
'max_stack_depth', 'bgwriter_lru_maxpages', 'max_worker_processes'])
if not data[0]:
return data[1]
for k, v in args.items():
sedConf(k, v)
restart()
3 years ago
return mw.returnJson(True, '设置成功!')
3 years ago
def setUserPwd(version=''):
args = getArgs()
data = checkArgs(args, ['password', 'name'])
if not data[0]:
return data[1]
3 years ago
3 years ago
newpwd = args['password']
username = args['name']
uid = args['id']
try:
pdb = pgDb()
psdb = pSqliteDb('databases')
name = psdb.where('id=?', (uid,)).getField('name')
3 years ago
3 years ago
r = pdb.execute(
"alter user {} with password '{}'".format(username, newpwd))
psdb.where("id=?", (uid,)).setField('password', newpwd)
return mw.returnJson(True, mw.getInfo('修改数据库[{1}]密码成功!', (name,)))
except Exception as ex:
return mw.returnJson(False, mw.getInfo('修改数据库[{1}]密码失败[{2}]!', (name, str(ex),)))
3 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
def setDbBackup():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
3 years ago
scDir = getPluginDir() + '/scripts/backup.py'
cmd = 'python3 ' + scDir + ' database ' + args['name'] + ' 3'
3 years ago
os.system(cmd)
return mw.returnJson(True, 'ok')
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)
3 years ago
pwd = pSqliteDb('config').where('id=?', (1,)).getField('pg_root')
3 years ago
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')
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():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
r = getDbBackupListFunc(args['name'])
bkDir = mw.getRootDir() + '/backup/database'
rr = []
for x in range(0, len(r)):
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)
data['file'] = p
return mw.returnJson(True, 'ok', rr)
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,rw,ps,addtime'
clist = conn.where(condition, ()).field(
field).limit(limit).order('id desc').select()
for x in range(0, len(clist)):
dbname = clist[x]['name']
blist = getDbBackupListFunc(dbname)
# print(blist)
clist[x]['is_backup'] = False
if len(blist) > 0:
clist[x]['is_backup'] = True
count = conn.where(condition, ()).count()
_page = {}
_page['count'] = count
_page['p'] = page
_page['row'] = page_size
_page['tojs'] = 'dbList'
data['page'] = mw.getPage(_page)
data['data'] = clist
info = {}
info['root_pwd'] = pSqliteDb('config').where(
3 years ago
'id=?', (1,)).getField('pg_root')
3 years ago
data['info'] = info
return mw.getJson(data)
3 years ago
def syncGetDatabases():
pdb = pgDb()
psdb = pSqliteDb('databases')
3 years ago
data = pdb.table('pg_database').field(
'datname').where("datistemplate=false").select()
3 years ago
nameArr = ['postgres']
3 years ago
n = 0
for value in data:
3 years ago
vdb_name = value["datname"]
3 years ago
b = False
for key in nameArr:
if vdb_name == key:
b = True
break
if b:
continue
if psdb.where("name=?", (vdb_name,)).count() > 0:
continue
3 years ago
host = '127.0.0.1/32'
ps = vdb_name
3 years ago
addTime = time.strftime('%Y-%m-%d %X', time.localtime())
if psdb.add('name,username,password,accept,ps,addtime', (vdb_name, vdb_name, '', host, ps, addTime)):
n += 1
msg = mw.getInfo('本次共从服务器获取了{1}个数据库!', (str(n),))
return mw.returnJson(True, msg)
3 years ago
def addDb():
args = getArgs()
3 years ago
data = checkArgs(args, ['password', 'name', 'db_user', 'dataAccess'])
3 years ago
if not data[0]:
return data[1]
3 years ago
address = ''
if 'address' in args:
3 years ago
address = args['address'].strip()
dbname = args['name'].strip()
dbuser = args['db_user'].strip()
password = args['password'].strip()
dataAccess = args['dataAccess'].strip()
3 years ago
listen_ip = "127.0.0.1/32"
if 'listen_ip' in args:
listen_ip = args['listen_ip'].strip()
if not re.match(r"(?:[0-9]{1,3}\.){3}[0-9]{1,3}/\d+", listen_ip):
return mw.returnJson(False, "你输入的权限不合法,添加失败!")
3 years ago
# 修改监听所有地址
if listen_ip not in ["127.0.0.1/32", "localhost", "127.0.0.1"]:
sedConf("listen_addresses", "'*'")
3 years ago
reg = "^[\w\.-]+$"
3 years ago
if not re.match(reg, dbname):
3 years ago
return mw.returnJson(False, '数据库名称不能带有特殊符号!')
3 years ago
checks = ['root', 'mysql', 'test', 'sys', 'postgres', 'postgresql']
3 years ago
if dbuser in checks or len(dbuser) < 1:
return mw.returnJson(False, '数据库用户名不合法!')
if dbname in checks or len(dbname) < 1:
return mw.returnJson(False, '数据库名称不合法!')
if len(password) < 1:
password = mw.md5(time.time())[0:8]
pdb = pgDb()
psdb = pSqliteDb('databases')
3 years ago
3 years ago
if psdb.where("name=? or username=?", (dbname, dbuser)).count():
3 years ago
return mw.returnJson(False, '数据库或用户已存在!')
3 years ago
3 years ago
sql = "select pg_terminate_backend(pid) from pg_stat_activity where DATNAME = 'template1';"
pdb.execute(sql)
3 years ago
r = pdb.execute("create database " + dbname)
3 years ago
# print(r)
3 years ago
r = pdb.execute("create user " + dbuser)
3 years ago
# print(r)
3 years ago
pdb.execute("alter user {} with password '{}'".format(dbuser, password,))
pdb.execute(
"GRANT ALL PRIVILEGES ON DATABASE {} TO {}".format(dbname, dbuser,))
3 years ago
3 years ago
pg_hba = getServerDir() + "/data/pg_hba.conf"
3 years ago
3 years ago
content = mw.readFile(pg_hba)
content += "\nhost {} {} {} md5".format(
dbname, dbuser, listen_ip)
mw.writeFile(pg_hba, content)
3 years ago
addTime = time.strftime('%Y-%m-%d %X', time.localtime())
psdb.add('pid,name,username,password,accept,ps,addtime',
3 years ago
(0, dbname, dbuser, password, listen_ip, dbname, addTime))
3 years ago
restart()
3 years ago
return mw.returnJson(True, '添加成功!')
3 years ago
def delDb():
args = getArgs()
data = checkArgs(args, ['id', 'name'])
if not data[0]:
return data[1]
did = args['id']
name = args['name']
pdb = pgDb()
psdb = pSqliteDb('databases')
username = psdb.where('id=?', (did,)).getField('username')
3 years ago
# print(username, len(username))
if len(username) > 0:
r = pdb.execute("drop user " + str(username))
# print(r)
sql = "SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE datname='" + \
name + "' AND pid<>pg_backend_pid();"
r = pdb.execute(sql)
# print(r)
r = pdb.execute("drop database " + name)
# print(r)
3 years ago
pg_hba = getServerDir() + "/data/pg_hba.conf"
old_config = mw.readFile(pg_hba)
new_config = re.sub(r'host\s*{}.*'.format(name), '', old_config).strip()
mw.writeFile(pg_hba, new_config)
psdb.where("id=?", (did,)).delete()
return mw.returnJson(True, '删除成功!')
3 years ago
def setDbRw(version=''):
args = getArgs()
data = checkArgs(args, ['username', 'id', 'rw'])
if not data[0]:
return data[1]
username = args['username']
uid = args['id']
rw = args['rw']
pdb = pgDb()
psdb = pSqliteDb('databases')
dbname = psdb.where("id=?", (uid,)).getField('name')
3 years ago
sql = "REVOKE ALL ON database " + dbname + " FROM " + username
pdb.query(sql)
3 years ago
if rw == 'rw':
sql = "GRANT SELECT, INSERT, UPDATE, DELETE ON database " + dbname + " TO " + username
elif rw == 'r':
sql = "GRANT SELECT ON database " + dbname + " TO " + username
else:
sql = "GRANT all ON database " + dbname + " TO " + username
r = pdb.execute(sql)
psdb.where("id=?", (uid,)).setField('rw', rw)
return mw.returnJson(True, '切换成功!')
3 years ago
def getDbAccess():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
name = args['name']
psdb = pSqliteDb('databases')
accept = psdb.where("name=?", (name,)).getField('accept')
return mw.returnJson(True, accept)
def setDbAccess():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
name = args['name']
return mw.returnJson(True, "设置成功")
def pgBack():
# 备份数据库
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
3 years ago
bk_path_upload = getBackupDir()
3 years ago
database = args['name']
port = getPgPort()
cmd = '''su - postgres -c "/www/server/pgsql/bin/pg_dump -c {} -p {} "| gzip > {}/{}_{}.gz '''.format(
database, port, bk_path_upload, database, time.strftime("%Y%m%d_%H%M%S"))
if mw.isAppleSystem():
cmd = '''{}/bin/pg_dump -c {} -p {} | gzip > {}/{}_{}.gz '''.format(
getServerDir(), database, port, bk_path_upload, database, time.strftime("%Y%m%d_%H%M%S"))
mw.execShell(cmd)
return mw.returnJson(True, '备份成功!')
def pgBackList():
args = getArgs()
data = checkArgs(args, ['name'])
if not data[0]:
return data[1]
database = args['name']
3 years ago
bk_path_upload = getBackupDir()
3 years ago
file_list = os.listdir(bk_path_upload)
data = []
for i in file_list:
if i.split("_")[0].startswith(database):
file_path = os.path.join(bk_path_upload, i)
file_info = os.stat(file_path)
create_time = file_info.st_ctime
time_local = time.localtime(int(create_time))
create_time = time.strftime("%Y-%m-%d %H:%M:%S", time_local)
file_size = file_info.st_size
file_size = mw.toSize(file_size)
data.append({"name": i, "time": create_time,
"size": file_size, "file": file_path})
return mw.returnJson(True, 'ok', data)
def importDbBackup():
args = getArgs()
data = checkArgs(args, ['file', 'name'])
if not data[0]:
return data[1]
file = args['file']
name = args['name']
3 years ago
bk_path_upload = getBackupDir()
3 years ago
file_path = os.path.join(bk_path_upload, name)
if not os.path.exists(file_path):
return mw.returnJson(False, '备份文件不存在')
port = getPgPort()
cmd = '''gunzip -c {}|su - postgres -c " /www/server/pgsql/bin/psql -d {} -p {} " '''.format(
file, name, port)
if mw.isAppleSystem():
cmd = '''gunzip -c {} | {}/bin/psql -d {} -p {}'''.format(
name, getServerDir(), port)
# print(cmd)
mw.execShell(cmd)
return mw.returnJson(True, '恢复数据库成功')
def deleteDbBackup():
args = getArgs()
data = checkArgs(args, ['filename'])
if not data[0]:
return data[1]
3 years ago
bk_path_upload = getBackupDir()
3 years ago
os.remove(bk_path_upload + '/' + args['filename'])
return mw.returnJson(True, 'ok')
3 years ago
def installPreInspection(version):
return 'ok'
def uninstallPreInspection(version):
return 'ok'
if __name__ == "__main__":
func = sys.argv[1]
version = "14.4"
version_pl = getServerDir() + "/version.pl"
if os.path.exists(version_pl):
version = mw.readFile(version_pl).strip()
if func == 'status':
print(status(version))
elif func == 'start':
print(start(version))
elif func == 'stop':
print(stop(version))
elif func == 'restart':
print(restart(version))
elif func == 'reload':
print(reload(version))
elif func == 'initd_status':
print(initdStatus())
elif func == 'initd_install':
print(initdInstall())
elif func == 'initd_uninstall':
print(initdUinstall())
elif func == 'install_pre_inspection':
print(installPreInspection(version))
elif func == 'uninstall_pre_inspection':
print(uninstallPreInspection(version))
elif func == 'conf':
print(getConf())
3 years ago
elif func == 'pg_hba_conf':
print(pgHbaConf())
3 years ago
elif func == 'config_tpl':
print(configTpl())
elif func == 'read_config_tpl':
print(readConfigTpl())
3 years ago
elif func == 'run_info':
print(runInfo())
3 years ago
elif func == 'run_log':
print(runLog())
3 years ago
elif func == 'slow_log':
print(getSlowLog())
3 years ago
elif func == 'db_status':
print(pgDbStatus())
3 years ago
elif func == 'set_db_status':
print(pgSetDbStatus())
3 years ago
elif func == 'set_user_pwd':
print(setUserPwd())
3 years ago
elif func == 'pg_port':
print(getPgPort())
elif func == 'set_pg_port':
print(setPgPort())
elif func == 'get_db_list':
print(getDbList())
3 years ago
elif func == 'add_db':
print(addDb())
3 years ago
elif func == 'del_db':
print(delDb())
3 years ago
elif func == 'set_db_rw':
print(setDbRw(version))
3 years ago
elif func == 'get_db_access':
print(getDbAccess())
elif func == 'set_db_access':
print(setDbAccess())
elif func == 'pg_back':
print(pgBack())
elif func == 'pg_back_list':
print(pgBackList())
elif func == 'import_db_backup':
print(importDbBackup())
elif func == 'delete_db_backup':
print(deleteDbBackup())
3 years ago
elif func == 'sync_get_databases':
print(syncGetDatabases())
3 years ago
else:
print('error')