mdserver-web/plugins/openresty/index.py

479 lines
13 KiB
Python
Raw Normal View History

2018-12-05 01:00:31 -05:00
# coding:utf-8
import sys
import io
import os
import time
2022-09-11 06:59:16 -04:00
import threading
2018-12-16 10:29:35 -05:00
import subprocess
2022-10-28 14:46:27 -04:00
import re
2018-12-05 01:00:31 -05:00
sys.path.append(os.getcwd() + "/class/core")
2020-07-10 03:57:25 -04:00
import mw
2018-12-05 01:00:31 -05:00
2018-12-07 06:12:18 -05:00
app_debug = False
2018-12-18 06:37:46 -05:00
2020-07-10 03:57:25 -04:00
if mw.isAppleSystem():
2018-12-07 06:12:18 -05:00
app_debug = True
def getPluginName():
return 'openresty'
def getPluginDir():
2020-07-10 03:57:25 -04:00
return mw.getPluginDir() + '/' + getPluginName()
2018-12-07 06:12:18 -05:00
def getServerDir():
2020-07-10 03:57:25 -04:00
return mw.getServerDir() + '/' + getPluginName()
2018-12-07 06:12:18 -05:00
def getInitDFile():
if app_debug:
return '/tmp/' + getPluginName()
return '/etc/init.d/' + getPluginName()
2018-12-16 10:29:35 -05:00
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
2022-10-28 14:46:27 -04:00
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'))
2018-12-07 23:42:02 -05:00
def clearTemp():
path_bin = getServerDir() + "/nginx"
2020-07-10 03:57:25 -04:00
mw.execShell('rm -rf ' + path_bin + '/client_body_temp')
mw.execShell('rm -rf ' + path_bin + '/fastcgi_temp')
mw.execShell('rm -rf ' + path_bin + '/proxy_temp')
mw.execShell('rm -rf ' + path_bin + '/scgi_temp')
mw.execShell('rm -rf ' + path_bin + '/uwsgi_temp')
2018-12-07 23:42:02 -05:00
2018-12-07 06:12:18 -05:00
def getConf():
2019-02-09 23:43:24 -05:00
path = getServerDir() + "/nginx/conf/nginx.conf"
2018-12-07 06:12:18 -05:00
return path
2019-02-25 02:18:08 -05:00
def getConfTpl():
path = getPluginDir() + '/conf/nginx.conf'
return path
2018-12-16 22:06:58 -05:00
def getOs():
data = {}
2020-07-10 03:57:25 -04:00
data['os'] = mw.getOs()
2018-12-16 22:06:58 -05:00
ng_exe_bin = getServerDir() + "/nginx/sbin/nginx"
if checkAuthEq(ng_exe_bin, 'root'):
data['auth'] = True
else:
data['auth'] = False
2020-07-10 03:57:25 -04:00
return mw.getJson(data)
2018-12-16 22:06:58 -05:00
2018-12-07 06:12:18 -05:00
def getInitDTpl():
path = getPluginDir() + "/init.d/nginx.tpl"
return path
2018-12-16 22:06:58 -05:00
def getFileOwner(filename):
import pwd
stat = os.lstat(filename)
uid = stat.st_uid
pw = pwd.getpwuid(uid)
return pw.pw_name
def checkAuthEq(file, owner='root'):
fowner = getFileOwner(file)
if (fowner == owner):
return True
return False
2018-12-07 06:12:18 -05:00
def confReplace():
service_path = os.path.dirname(os.getcwd())
2020-07-10 03:57:25 -04:00
content = mw.readFile(getConfTpl())
2018-12-07 06:12:18 -05:00
content = content.replace('{$SERVER_PATH}', service_path)
2018-12-08 02:47:40 -05:00
user = 'www'
user_group = 'www'
2018-12-16 22:06:58 -05:00
2020-07-10 03:57:25 -04:00
if mw.getOs() == 'darwin':
2018-12-16 22:06:58 -05:00
# macosx do
2020-07-10 03:57:25 -04:00
user = mw.execShell(
2018-12-07 06:12:18 -05:00
"who | sed -n '2, 1p' |awk '{print $1}'")[0].strip()
2018-12-08 02:47:40 -05:00
# user = 'root'
user_group = 'staff'
2018-12-07 23:42:02 -05:00
content = content.replace('{$EVENT_MODEL}', 'kqueue')
2018-12-07 06:12:18 -05:00
else:
2018-12-07 23:42:02 -05:00
content = content.replace('{$EVENT_MODEL}', 'epoll')
2018-12-08 02:47:40 -05:00
content = content.replace('{$OS_USER}', user)
content = content.replace('{$OS_USER_GROUP}', user_group)
2018-12-07 06:12:18 -05:00
# 主配置文件
2019-04-23 12:15:01 -04:00
nconf = getServerDir() + '/nginx/conf/nginx.conf'
2022-06-26 09:47:13 -04:00
mw.writeFile(nconf, content)
# 静态配置
2022-06-28 12:42:16 -04:00
php_conf = mw.getServerDir() + '/web_conf/php/conf'
if not os.path.exists(php_conf):
mw.execShell('mkdir -p ' + php_conf)
static_conf = mw.getServerDir() + '/web_conf/php/conf/enable-php-00.conf'
2022-06-22 01:44:35 -04:00
if not os.path.exists(static_conf):
2022-07-04 21:26:52 -04:00
mw.writeFile(static_conf, 'set $PHP_ENV 0;')
2018-12-07 06:12:18 -05:00
2018-12-16 22:06:58 -05:00
# give nginx root permission
2018-12-08 03:25:45 -05:00
ng_exe_bin = getServerDir() + "/nginx/sbin/nginx"
2018-12-16 22:06:58 -05:00
if not checkAuthEq(ng_exe_bin, 'root'):
args = getArgs()
sudoPwd = args['pwd']
cmd_own = 'chown -R ' + 'root:' + user_group + ' ' + ng_exe_bin
os.system('echo %s|sudo -S %s' % (sudoPwd, cmd_own))
cmd_mod = 'chmod 755 ' + ng_exe_bin
os.system('echo %s|sudo -S %s' % (sudoPwd, cmd_mod))
cmd_s = 'chmod u+s ' + ng_exe_bin
os.system('echo %s|sudo -S %s' % (sudoPwd, cmd_s))
2018-12-08 02:47:40 -05:00
2018-12-07 06:12:18 -05:00
def initDreplace():
file_tpl = getInitDTpl()
service_path = os.path.dirname(os.getcwd())
initD_path = getServerDir() + '/init.d'
2020-06-02 11:05:53 -04:00
2022-06-18 00:55:27 -04:00
# OpenResty is not installed
2020-06-02 11:05:53 -04:00
if not os.path.exists(getServerDir()):
2021-05-09 12:13:32 -04:00
print("ok")
2020-06-02 11:05:53 -04:00
exit(0)
2022-06-18 00:55:27 -04:00
# init.d
2020-07-10 13:24:54 -04:00
file_bin = initD_path + '/' + getPluginName()
2018-12-07 06:12:18 -05:00
if not os.path.exists(initD_path):
os.mkdir(initD_path)
2020-07-10 13:24:54 -04:00
# initd replace
content = mw.readFile(file_tpl)
content = content.replace('{$SERVER_PATH}', service_path)
mw.writeFile(file_bin, content)
mw.execShell('chmod +x ' + file_bin)
2018-12-07 06:12:18 -05:00
2020-07-10 13:24:54 -04:00
# config replace
confReplace()
2018-12-07 06:12:18 -05:00
2022-06-18 00:55:27 -04:00
# systemd
2022-07-11 02:02:52 -04:00
# /usr/lib/systemd/system
2022-07-11 01:49:25 -04:00
systemDir = mw.systemdCfgDir()
2022-06-18 00:55:27 -04:00
systemService = systemDir + '/openresty.service'
systemServiceTpl = getPluginDir() + '/init.d/openresty.service.tpl'
if os.path.exists(systemDir) and not os.path.exists(systemService):
se_content = mw.readFile(systemServiceTpl)
se_content = se_content.replace('{$SERVER_PATH}', service_path)
mw.writeFile(systemService, se_content)
mw.execShell('systemctl daemon-reload')
2018-12-07 06:12:18 -05:00
return file_bin
2018-12-05 01:00:31 -05:00
def status():
2020-07-10 03:57:25 -04:00
data = mw.execShell(
2022-07-03 10:02:17 -04:00
"ps -ef|grep openresty |grep -v grep | grep -v python | awk '{print $2}'")
2018-12-05 01:00:31 -05:00
if data[0] == '':
return 'stop'
return 'start'
2022-06-19 01:55:54 -04:00
def restyOp(method):
2022-06-19 01:56:23 -04:00
file = initDreplace()
2022-06-18 01:37:38 -04:00
2022-06-28 14:22:43 -04:00
# 启动时,先检查一下配置文件
check = getServerDir() + "/bin/openresty -t"
check_data = mw.execShell(check)
2022-07-27 02:19:30 -04:00
if not check_data[1].find('test is successful') > -1:
2022-06-28 14:22:43 -04:00
return check_data[1]
2022-06-18 01:37:38 -04:00
if not mw.isAppleSystem():
2022-06-18 02:40:06 -04:00
data = mw.execShell('systemctl ' + method + ' openresty')
2022-06-18 01:37:38 -04:00
if data[1] == '':
return 'ok'
2022-07-05 22:42:54 -04:00
return data[1]
2022-06-18 01:37:38 -04:00
2022-06-18 02:40:06 -04:00
data = mw.execShell(file + ' ' + method)
2018-12-07 06:12:18 -05:00
if data[1] == '':
2018-12-05 01:00:31 -05:00
return 'ok'
2018-12-20 00:29:05 -05:00
return data[1]
2018-12-05 01:00:31 -05:00
def op_submit_systemctl_restart():
2022-09-11 06:45:44 -04:00
mw.execShell('systemctl restart openresty')
def op_submit_init_restart(file):
2022-09-11 06:45:44 -04:00
mw.execShell(file + ' restart')
2022-09-11 06:45:44 -04:00
def restyOp_restart():
file = initDreplace()
# 启动时,先检查一下配置文件
check = getServerDir() + "/bin/openresty -t"
check_data = mw.execShell(check)
if not check_data[1].find('test is successful') > -1:
2022-10-28 14:46:27 -04:00
return 'ERROR: 配置出错<br><a style="color:red;">' + check_data[1].replace("\n", '<br>') + '</a>'
2022-09-11 06:45:44 -04:00
if not mw.isAppleSystem():
threading.Timer(2, op_submit_systemctl_restart, args=()).start()
# submit_restart1()
2022-09-11 06:45:44 -04:00
return 'ok'
threading.Timer(2, op_submit_init_restart, args=(file,)).start()
# submit_restart2(file)
2022-09-11 06:45:44 -04:00
return 'ok'
2018-12-05 01:00:31 -05:00
2022-06-18 02:40:06 -04:00
def start():
2022-06-19 01:54:44 -04:00
return restyOp('start')
2022-06-18 01:37:38 -04:00
2022-06-18 02:40:06 -04:00
def stop():
2022-06-19 01:54:44 -04:00
return restyOp('stop')
2018-12-07 06:12:18 -05:00
def restart():
2022-09-11 06:45:44 -04:00
return restyOp_restart()
2018-12-05 01:00:31 -05:00
def reload():
2022-06-19 01:54:44 -04:00
return restyOp('reload')
2018-12-07 06:12:18 -05:00
def initdStatus():
2022-06-18 00:55:27 -04:00
if mw.isAppleSystem():
return "Apple Computer does not support"
shell_cmd = 'systemctl status openresty | grep loaded | grep "enabled;"'
data = mw.execShell(shell_cmd)
if data[0] == '':
return 'fail'
return 'ok'
2018-12-05 01:00:31 -05:00
2018-12-07 06:12:18 -05:00
def initdInstall():
2022-06-18 00:55:27 -04:00
if mw.isAppleSystem():
return "Apple Computer does not support"
mw.execShell('systemctl enable openresty')
2018-12-07 06:12:18 -05:00
return 'ok'
def initdUinstall():
2022-06-18 00:55:27 -04:00
if mw.isAppleSystem():
return "Apple Computer does not support"
2019-04-23 12:15:01 -04:00
2022-06-18 00:55:27 -04:00
mw.execShell('systemctl disable openresty')
2018-12-07 06:12:18 -05:00
return 'ok'
2018-12-05 07:15:00 -05:00
2018-12-08 03:24:36 -05:00
def runInfo():
# 取Openresty负载状态
2018-12-10 02:10:07 -05:00
try:
2022-10-28 14:46:27 -04:00
url = 'http://127.0.0.1/nginx_status'
2022-11-24 05:21:25 -05:00
result = mw.httpGet(url, timeout=1)
2018-12-10 02:10:07 -05:00
tmp = result.split()
data = {}
data['active'] = tmp[2]
data['accepts'] = tmp[9]
data['handled'] = tmp[7]
data['requests'] = tmp[8]
data['Reading'] = tmp[11]
data['Writing'] = tmp[13]
data['Waiting'] = tmp[15]
2020-07-10 03:57:25 -04:00
return mw.getJson(data)
2018-12-10 02:10:07 -05:00
except Exception as e:
2022-10-28 14:46:27 -04:00
url = 'http://' + mw.getHostAddr() + '/nginx_status'
2022-06-22 14:49:49 -04:00
result = mw.httpGet(url)
tmp = result.split()
data = {}
data['active'] = tmp[2]
data['accepts'] = tmp[9]
data['handled'] = tmp[7]
data['requests'] = tmp[8]
data['Reading'] = tmp[11]
data['Writing'] = tmp[13]
data['Waiting'] = tmp[15]
return mw.getJson(data)
2022-06-22 15:20:45 -04:00
except Exception as e:
2018-12-10 02:10:07 -05:00
return 'oprenresty not started'
2018-12-08 03:24:36 -05:00
2018-12-09 22:42:13 -05:00
def errorLogPath():
return getServerDir() + '/nginx/logs/error.log'
2022-10-28 14:46:27 -04:00
def getCfg():
cfg = getConf()
content = mw.readFile(cfg)
unitrep = "[kmgKMG]"
cfg_args = [
{"name": "worker_processes", "ps": "处理进程,auto表示自动,数字表示进程数", 'type': 2},
{"name": "worker_connections", "ps": "最大并发链接数", 'type': 2},
{"name": "keepalive_timeout", "ps": "连接超时时间", 'type': 2},
{"name": "gzip", "ps": "是否开启压缩传输", 'type': 1},
{"name": "gzip_min_length", "ps": "最小压缩文件", 'type': 2},
{"name": "gzip_comp_level", "ps": "压缩率", 'type': 2},
{"name": "client_max_body_size", "ps": "最大上传文件", 'type': 2},
{"name": "server_names_hash_bucket_size",
"ps": "服务器名字的hash表大小", 'type': 2},
{"name": "client_header_buffer_size", "ps": "客户端请求头buffer大小", 'type': 2},
]
# {"name": "client_body_buffer_size", "ps": "请求主体缓冲区"}
rdata = []
for i in cfg_args:
rep = "(%s)\s+(\w+)" % i["name"]
k = re.search(rep, content)
if not k:
return mw.returnJson(False, "获取 key {} 失败".format(k))
k = k.group(1)
v = re.search(rep, content)
if not v:
return mw.returnJson(False, "获取 value {} 失败".format(v))
v = v.group(2)
if re.search(unitrep, v):
u = str.upper(v[-1])
v = v[:-1]
if len(u) == 1:
psstr = u + "B" + i["ps"]
else:
psstr = u + "" + i["ps"]
else:
u = ""
kv = {"name": k, "value": v, "unit": u,
"ps": i["ps"], "type": i["type"]}
rdata.append(kv)
return mw.returnJson(True, "ok", rdata)
def setCfg():
args = getArgs()
data = checkArgs(args, [
'worker_processes', 'worker_connections', 'keepalive_timeout',
'gzip', 'gzip_min_length', 'gzip_comp_level', 'client_max_body_size',
'server_names_hash_bucket_size', 'client_header_buffer_size'
])
if not data[0]:
return data[1]
cfg = getConf()
mw.backFile(cfg)
content = mw.readFile(cfg)
unitrep = "[kmgKMG]"
cfg_args = [
{"name": "worker_processes", "ps": "处理进程,auto表示自动,数字表示进程数", 'type': 2},
{"name": "worker_connections", "ps": "最大并发链接数", 'type': 2},
{"name": "keepalive_timeout", "ps": "连接超时时间", 'type': 2},
{"name": "gzip", "ps": "是否开启压缩传输", 'type': 1},
{"name": "gzip_min_length", "ps": "最小压缩文件", 'type': 2},
{"name": "gzip_comp_level", "ps": "压缩率", 'type': 2},
{"name": "client_max_body_size", "ps": "最大上传文件", 'type': 2},
{"name": "server_names_hash_bucket_size",
"ps": "服务器名字的hash表大小", 'type': 2},
{"name": "client_header_buffer_size", "ps": "客户端请求头buffer大小", 'type': 2},
]
# print(args)
for k, v in args.items():
# print(k, v)
rep = "%s\s+[^kKmMgG\;\n]+" % k
if k == "worker_processes" or k == "gzip":
if not re.search("auto|on|off|\d+", v):
return mw.returnJson(False, '参数值错误')
else:
if not re.search("\d+", v):
return mw.returnJson(False, '参数值错误,请输入数字整数')
if re.search(rep, content):
newconf = "%s %s" % (k, v)
content = re.sub(rep, newconf, content)
elif re.search(rep, content):
newconf = "%s %s" % (k, v)
content = re.sub(rep, newconf, content)
mw.writeFile(cfg, content)
isError = mw.checkWebConfig()
if (isError != True):
mw.restoreFile(cfg)
return mw.returnJson(False, 'ERROR: 配置出错<br><a style="color:red;">' + isError.replace("\n", '<br>') + '</a>')
mw.restartWeb()
return mw.returnJson(True, '设置成功')
2022-08-12 00:07:08 -04:00
def installPreInspection():
return 'ok'
2018-12-05 01:00:31 -05:00
if __name__ == "__main__":
func = sys.argv[1]
if func == 'status':
2021-05-01 05:42:19 -04:00
print(status())
2018-12-05 01:00:31 -05:00
elif func == 'start':
2021-05-01 05:42:19 -04:00
print(start())
2018-12-05 01:00:31 -05:00
elif func == 'stop':
2021-05-01 05:42:19 -04:00
print(stop())
2018-12-07 23:42:02 -05:00
elif func == 'restart':
2021-05-01 05:42:19 -04:00
print(restart())
2018-12-05 01:00:31 -05:00
elif func == 'reload':
2021-05-01 05:42:19 -04:00
print(reload())
2018-12-07 06:12:18 -05:00
elif func == 'initd_status':
2021-05-01 05:42:19 -04:00
print(initdStatus())
2018-12-07 06:12:18 -05:00
elif func == 'initd_install':
2021-05-01 05:42:19 -04:00
print(initdInstall())
2018-12-07 06:12:18 -05:00
elif func == 'initd_uninstall':
2021-05-01 05:42:19 -04:00
print(initdUinstall())
2022-08-12 00:07:08 -04:00
elif func == 'install_pre_inspection':
print(installPreInspection())
2018-12-05 07:15:00 -05:00
elif func == 'conf':
2021-05-01 05:42:19 -04:00
print(getConf())
2018-12-16 10:29:35 -05:00
elif func == 'get_os':
2021-05-01 05:42:19 -04:00
print(getOs())
2018-12-08 03:24:36 -05:00
elif func == 'run_info':
2021-05-01 05:42:19 -04:00
print(runInfo())
2018-12-09 22:42:13 -05:00
elif func == 'error_log':
2021-05-01 05:42:19 -04:00
print(errorLogPath())
2022-10-28 14:46:27 -04:00
elif func == 'get_cfg':
print(getCfg())
elif func == 'set_cfg':
print(setCfg())
2018-12-05 01:00:31 -05:00
else:
2021-05-01 05:42:19 -04:00
print('error')