From 759e1432f8ca24bd36823483e48675184d848606 Mon Sep 17 00:00:00 2001 From: midoks Date: Sun, 22 Oct 2023 17:45:39 +0800 Subject: [PATCH] keepalived debug --- .gitignore | 1 - plugins/keepalived/config/keepalived.conf | 0 plugins/keepalived/ico.png | Bin 0 -> 562 bytes plugins/keepalived/index.html | 21 + plugins/keepalived/index.py | 387 ++++++++++++++++++ plugins/keepalived/info.json | 17 + .../keepalived/init.d/keepalived.service.tpl | 12 + plugins/keepalived/init.d/keepalived.tpl | 73 ++++ plugins/keepalived/install.sh | 79 ++++ plugins/keepalived/js/keepalived.js | 143 +++++++ 10 files changed, 732 insertions(+), 1 deletion(-) create mode 100644 plugins/keepalived/config/keepalived.conf create mode 100644 plugins/keepalived/ico.png create mode 100755 plugins/keepalived/index.html create mode 100755 plugins/keepalived/index.py create mode 100755 plugins/keepalived/info.json create mode 100644 plugins/keepalived/init.d/keepalived.service.tpl create mode 100644 plugins/keepalived/init.d/keepalived.tpl create mode 100755 plugins/keepalived/install.sh create mode 100755 plugins/keepalived/js/keepalived.js diff --git a/.gitignore b/.gitignore index a2241fa9c..e6db47a0a 100644 --- a/.gitignore +++ b/.gitignore @@ -165,7 +165,6 @@ plugins/tamper_proof plugins/cryptocurrency_trade plugins/mtproxy plugins/zimg -plugins/keepalived plugins/bk_demo plugins/mail plugins/fastdfs diff --git a/plugins/keepalived/config/keepalived.conf b/plugins/keepalived/config/keepalived.conf new file mode 100644 index 000000000..e69de29bb diff --git a/plugins/keepalived/ico.png b/plugins/keepalived/ico.png new file mode 100644 index 0000000000000000000000000000000000000000..383c6b9ade920e6a6d6f9789d45529cb40ce236f GIT binary patch literal 562 zcmV-20?qx2P)Px$>`6pHR9Hvtmpv~9K@^6ci--s+Eq{R!5`;>n(n*MtN=fOf#vjmWXjBqJA|gr> zjYdHtD2Pgr$eYY2o3Y=!bMHoWnwz^jd-mCPX5Mp7jgpUA$@!=N^R7^(V51bA02a;5 zcY&+CAYspES>it67HBd-e}I1AE(Wp_SOwb5?`M*a$^y6yY+1o|Z71S|g1ZC;%$$8- z&K2MWux(^S%c`I(#KD?r6nxpfFkTYEB9E$9+Zv0H%CfPz*2 zD4%R-!RiTD>XP4stb5ZG)OM}_+Yza)3%CFV%^as~=MZph!3+a8F}YVpzE+RMT^wo| zy@u$-^dLpl27h8?$;D1U!h%+SdF8GY{Pzm}0!n#xDc(!`*8l(j07*qoM6N<$g07wP Aa{vGU literal 0 HcmV?d00001 diff --git a/plugins/keepalived/index.html b/plugins/keepalived/index.html new file mode 100755 index 000000000..911a26493 --- /dev/null +++ b/plugins/keepalived/index.html @@ -0,0 +1,21 @@ +
+
+
+
+

服务

+

自启动

+

配置修改

+

性能调整

+

负载状态

+

日志

+
+
+
+
+
+
+ \ No newline at end of file diff --git a/plugins/keepalived/index.py b/plugins/keepalived/index.py new file mode 100755 index 000000000..dadb83506 --- /dev/null +++ b/plugins/keepalived/index.py @@ -0,0 +1,387 @@ +# coding:utf-8 + +import sys +import io +import os +import time +import re + +sys.path.append(os.getcwd() + "/class/core") +import mw + +app_debug = False +if mw.isAppleSystem(): + app_debug = True + + +def getPluginName(): + return 'redis' + + +def getPluginDir(): + return mw.getPluginDir() + '/' + getPluginName() + + +def getServerDir(): + return mw.getServerDir() + '/' + getPluginName() + + +def getInitDFile(): + current_os = mw.getOs() + if current_os == 'darwin': + return '/tmp/' + getPluginName() + + if current_os.startswith('freebsd'): + return '/etc/rc.d/' + getPluginName() + + return '/etc/init.d/' + getPluginName() + + +def getConf(): + path = getServerDir() + "/redis.conf" + return path + + +def getConfTpl(): + path = getPluginDir() + "/config/redis.conf" + return path + + +def getInitDTpl(): + path = getPluginDir() + "/init.d/" + getPluginName() + ".tpl" + return path + + +def getArgs(): + args = sys.argv[3:] + tmp = {} + args_len = len(args) + + if args_len == 1: + t = args[0].strip('{').strip('}') + if t.strip() == '': + tmp = [] + else: + t = t.split(':') + tmp[t[0]] = t[1] + 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 + + +def status(): + data = mw.execShell( + "ps aux|grep redis |grep -v grep | grep -v python | grep -v mdserver-web | awk '{print $2}'") + + if data[0] == '': + return 'stop' + return 'start' + + +def initDreplace(): + + file_tpl = getInitDTpl() + service_path = os.path.dirname(os.getcwd()) + + initD_path = getServerDir() + '/init.d' + if not os.path.exists(initD_path): + os.mkdir(initD_path) + file_bin = initD_path + '/' + getPluginName() + + # initd replace + if not os.path.exists(file_bin): + content = mw.readFile(file_tpl) + content = content.replace('{$SERVER_PATH}', service_path) + mw.writeFile(file_bin, content) + mw.execShell('chmod +x ' + file_bin) + + # log + dataLog = getServerDir() + '/data' + if not os.path.exists(dataLog): + mw.execShell('chmod +x ' + file_bin) + + # config replace + dst_conf = getServerDir() + '/redis.conf' + dst_conf_init = getServerDir() + '/init.pl' + if not os.path.exists(dst_conf_init): + conf_content = mw.readFile(getConfTpl()) + conf_content = conf_content.replace('{$SERVER_PATH}', service_path) + conf_content = conf_content.replace( + '{$REDIS_PASS}', mw.getRandomString(10)) + + mw.writeFile(dst_conf, conf_content) + mw.writeFile(dst_conf_init, 'ok') + + # systemd + systemDir = mw.systemdCfgDir() + systemService = systemDir + '/' + getPluginName() + '.service' + if os.path.exists(systemDir) and not os.path.exists(systemService): + systemServiceTpl = getPluginDir() + '/init.d/' + getPluginName() + '.service.tpl' + service_path = mw.getServerDir() + se_content = mw.readFile(systemServiceTpl) + se_content = se_content.replace('{$SERVER_PATH}', service_path) + mw.writeFile(systemService, se_content) + mw.execShell('systemctl daemon-reload') + + return file_bin + + +def redisOp(method): + file = initDreplace() + + current_os = mw.getOs() + if current_os == "darwin": + data = mw.execShell(file + ' ' + method) + if data[1] == '': + return 'ok' + return data[1] + + if current_os.startswith("freebsd"): + data = mw.execShell('service ' + getPluginName() + ' ' + method) + if data[1] == '': + return 'ok' + return data[1] + + data = mw.execShell('systemctl ' + method + ' redis') + if data[1] == '': + return 'ok' + return data[1] + + +def start(): + return redisOp('start') + + +def stop(): + return redisOp('stop') + + +def restart(): + status = redisOp('restart') + + log_file = runLog() + mw.execShell("echo '' > " + log_file) + return status + + +def reload(): + return redisOp('reload') + + +def getPort(): + conf = getServerDir() + '/redis.conf' + content = mw.readFile(conf) + + rep = "^(" + 'port' + ')\s*([.0-9A-Za-z_& ~]+)' + tmp = re.search(rep, content, re.M) + if tmp: + return tmp.groups()[1] + + return '6379' + + +def runInfo(): + s = status() + if s == 'stop': + return mw.returnJson(False, '未启动') + + requirepass = "" + + conf = getServerDir() + '/redis.conf' + content = mw.readFile(conf) + rep = "^(requirepass" + ')\s*([.0-9A-Za-z_& ~]+)' + tmp = re.search(rep, content, re.M) + if tmp: + requirepass = tmp.groups()[1] + + default_ip = '127.0.0.1' + port = getPort() + # findDebian = mw.execShell('cat /etc/issue |grep Debian') + # if findDebian[0] != '': + # default_ip = mw.getLocalIp() + cmd = getServerDir() + "/bin/redis-cli -h " + \ + default_ip + ' -p ' + port + " info" + + if requirepass != "": + cmd = getServerDir() + '/bin/redis-cli -h ' + default_ip + \ + ' -p ' + port + ' -a "' + requirepass + '" info' + + # print(cmd) + data = mw.execShell(cmd)[0] + res = [ + 'tcp_port', + 'uptime_in_days', # 已运行天数 + 'connected_clients', # 连接的客户端数量 + 'used_memory', # Redis已分配的内存总量 + 'used_memory_rss', # Redis占用的系统内存总量 + 'used_memory_peak', # Redis所用内存的高峰值 + 'mem_fragmentation_ratio', # 内存碎片比率 + 'total_connections_received', # 运行以来连接过的客户端的总数量 + 'total_commands_processed', # 运行以来执行过的命令的总数量 + 'instantaneous_ops_per_sec', # 服务器每秒钟执行的命令数量 + 'keyspace_hits', # 查找数据库键成功的次数 + 'keyspace_misses', # 查找数据库键失败的次数 + 'latest_fork_usec' # 最近一次 fork() 操作耗费的毫秒数 + ] + data = data.split("\n") + result = {} + for d in data: + if len(d) < 3: + continue + t = d.strip().split(':') + if not t[0] in res: + continue + result[t[0]] = t[1] + return mw.getJson(result) + + +def initdStatus(): + current_os = mw.getOs() + if current_os == 'darwin': + return "Apple Computer does not support" + + if current_os.startswith('freebsd'): + initd_bin = getInitDFile() + if os.path.exists(initd_bin): + return 'ok' + + shell_cmd = 'systemctl status ' + \ + getPluginName() + ' | grep loaded | grep "enabled;"' + data = mw.execShell(shell_cmd) + if data[0] == '': + return 'fail' + return 'ok' + + +def initdInstall(): + current_os = mw.getOs() + if current_os == 'darwin': + return "Apple Computer does not support" + + # freebsd initd install + if current_os.startswith('freebsd'): + import shutil + source_bin = initDreplace() + initd_bin = getInitDFile() + shutil.copyfile(source_bin, initd_bin) + mw.execShell('chmod +x ' + initd_bin) + mw.execShell('sysrc ' + getPluginName() + '_enable="YES"') + return 'ok' + + mw.execShell('systemctl enable ' + getPluginName()) + return 'ok' + + +def initdUinstall(): + current_os = mw.getOs() + if current_os == 'darwin': + return "Apple Computer does not support" + + if current_os.startswith('freebsd'): + initd_bin = getInitDFile() + os.remove(initd_bin) + mw.execShell('sysrc ' + getPluginName() + '_enable="NO"') + return 'ok' + + mw.execShell('systemctl disable ' + getPluginName()) + return 'ok' + + +def runLog(): + return getServerDir() + '/data/redis.log' + + +def getRedisConfInfo(): + conf = getServerDir() + '/redis.conf' + + gets = [ + {'name': 'bind', 'type': 2, 'ps': '绑定IP(修改绑定IP可能会存在安全隐患)'}, + {'name': 'port', 'type': 2, 'ps': '绑定端口'}, + {'name': 'timeout', 'type': 2, 'ps': '空闲链接超时时间,0表示不断开'}, + {'name': 'maxclients', 'type': 2, 'ps': '最大输入时间'}, + {'name': 'databases', 'type': 2, 'ps': '数据库数量'}, + {'name': 'requirepass', 'type': 2, 'ps': 'redis密码,留空代表没有设置密码'}, + {'name': 'maxmemory', 'type': 2, 'ps': 'MB,最大使用内存,0表示不限制'} + ] + content = mw.readFile(conf) + + result = [] + for g in gets: + rep = "^(" + g['name'] + ')\s*([.0-9A-Za-z_& ~]+)' + tmp = re.search(rep, content, re.M) + if not tmp: + g['value'] = '' + result.append(g) + continue + g['value'] = tmp.groups()[1] + if g['name'] == 'maxmemory': + g['value'] = g['value'].strip("mb") + result.append(g) + + return result + + +def getRedisConf(): + data = getRedisConfInfo() + return mw.getJson(data) + + +def submitRedisConf(): + gets = ['bind', 'port', 'timeout', 'maxclients', + 'databases', 'requirepass', 'maxmemory'] + args = getArgs() + conf = getServerDir() + '/redis.conf' + content = mw.readFile(conf) + for g in gets: + if g in args: + rep = g + '\s*([.0-9A-Za-z_& ~]+)' + val = g + ' ' + args[g] + + if g == 'maxmemory': + val = g + ' ' + args[g] + "mb" + + if g == 'requirepass' and args[g] == '': + content = re.sub('requirepass', '#requirepass', content) + if g == 'requirepass' and args[g] != '': + content = re.sub('#requirepass', 'requirepass', content) + content = re.sub(rep, val, content) + + if g != 'requirepass': + content = re.sub(rep, val, content) + mw.writeFile(conf, content) + reload() + return mw.returnJson(True, '设置成功') + +if __name__ == "__main__": + func = sys.argv[1] + if func == 'status': + print(status()) + elif func == 'start': + print(start()) + elif func == 'stop': + print(stop()) + elif func == 'restart': + print(restart()) + elif func == 'reload': + print(reload()) + elif func == 'initd_status': + print(initdStatus()) + elif func == 'initd_install': + print(initdInstall()) + elif func == 'initd_uninstall': + print(initdUinstall()) + elif func == 'run_info': + print(runInfo()) + elif func == 'conf': + print(getConf()) + elif func == 'run_log': + print(runLog()) + elif func == 'get_redis_conf': + print(getRedisConf()) + elif func == 'submit_redis_conf': + print(submitRedisConf()) + else: + print('error') diff --git a/plugins/keepalived/info.json b/plugins/keepalived/info.json new file mode 100755 index 000000000..9a78c2546 --- /dev/null +++ b/plugins/keepalived/info.json @@ -0,0 +1,17 @@ +{ + "sort": 7, + "ps": "优秀的高可用软件", + "name": "keepalived", + "title": "keepalived", + "shell": "install.sh", + "versions":["2.2.8"], + "tip": "soft", + "checks": "server/keepalived", + "path": "server/keepalived", + "display": 1, + "author": "keepalived", + "date": "2023-10-22", + "home": "https://keepalived.org/download.html", + "type": "soft", + "pid": "4" +} diff --git a/plugins/keepalived/init.d/keepalived.service.tpl b/plugins/keepalived/init.d/keepalived.service.tpl new file mode 100644 index 000000000..8e8eb5693 --- /dev/null +++ b/plugins/keepalived/init.d/keepalived.service.tpl @@ -0,0 +1,12 @@ +[Unit] +Description=Redis In-Memory Data Store +After=network.target + +[Service] +Type=forking +ExecStart={$SERVER_PATH}/redis/bin/redis-server {$SERVER_PATH}/redis/redis.conf +ExecReload=/bin/kill -USR2 $MAINPID +Restart=on-failure + +[Install] +WantedBy=multi-user.target \ No newline at end of file diff --git a/plugins/keepalived/init.d/keepalived.tpl b/plugins/keepalived/init.d/keepalived.tpl new file mode 100644 index 000000000..02e0440c2 --- /dev/null +++ b/plugins/keepalived/init.d/keepalived.tpl @@ -0,0 +1,73 @@ +#!/bin/sh +# chkconfig: 2345 55 25 +# description: Redis Service + +### BEGIN INIT INFO +# Provides: Redis +# Required-Start: $all +# Required-Stop: $all +# Default-Start: 2 3 4 5 +# Default-Stop: 0 1 6 +# Short-Description: starts Redis +# Description: starts the MDW-Web +### END INIT INFO + +# Simple Redis init.d script conceived to work on Linux systems +# as it does use of the /proc filesystem. + +CONF="{$SERVER_PATH}/redis/redis.conf" +REDISPORT=$(cat $CONF |grep port|grep -v '#'|awk '{print $2}') +REDISPASS=$(cat $CONF |grep requirepass|grep -v '#'|awk '{print $2}') +if [ "$REDISPASS" != "" ];then + REDISPASS=" -a $REDISPASS" +fi +EXEC={$SERVER_PATH}/redis/bin/redis-server +CLIEXEC="{$SERVER_PATH}/redis/bin/redis-cli -p $REDISPORT$REDISPASS" +PIDFILE={$SERVER_PATH}/redis/redis_6379.pid + +mkdir -p {$SERVER_PATH}/redis/data + +redis_start(){ + if [ -f $PIDFILE ];then + kill -9 `cat $PIDFILE` + fi + + echo "Starting Redis server..." + nohup $EXEC $CONF >> {$SERVER_PATH}/redis/logs.pl 2>&1 & +} +redis_stop(){ + if [ ! -f $PIDFILE ] + then + echo "$PIDFILE does not exist, process is not running" + else + PID=$(cat $PIDFILE) + echo "Stopping ..." + $CLIEXEC shutdown + while [ -x /proc/${PID} ] + do + echo "Waiting for Redis to shutdown ..." + sleep 1 + done + echo "Redis stopped" + rm -rf $PIDFILE + fi +} + + +case "$1" in + start) + redis_start + ;; + stop) + redis_stop + ;; + restart|reload) + redis_stop + sleep 0.3 + redis_start + ;; + *) + echo "Please use start or stop as first argument" + ;; +esac + diff --git a/plugins/keepalived/install.sh b/plugins/keepalived/install.sh new file mode 100755 index 000000000..c932b6dae --- /dev/null +++ b/plugins/keepalived/install.sh @@ -0,0 +1,79 @@ +#!/bin/bash +PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin +export PATH + +curPath=`pwd` +rootPath=$(dirname "$curPath") +rootPath=$(dirname "$rootPath") +serverPath=$(dirname "$rootPath") + +# cd /Users/midoks/Desktop/mwdev/server/mdserver-web/plugins/keepalived && bash install.sh install 2.2.8 +# cd /www/mdserver-web/plugins/keepalived && bash install.sh install 2.2.8 + +install_tmp=${rootPath}/tmp/mw_install.pl + +VERSION=$2 + +Install_App() +{ + echo '正在安装脚本文件...' > $install_tmp + mkdir -p $serverPath/source/keepalived + + if [ ! -f $serverPath/source/keepalived/keepalived-${VERSION}.tar.gz ];then + wget -O $serverPath/source/keepalived/keepalived-${VERSION}.tar.gz https://keepalived.org/software/keepalived-${VERSION}.tar.gz + fi + + #检测文件是否损坏. + md5_file_ok=8c26f75a8767e5341d82696e1e717115 + if [ -f $serverPath/source/keepalived/keepalived-${VERSION}.tar.gz ];then + md5_file=`md5sum $serverPath/source/keepalived/keepalived-${VERSION}.tar.gz | awk '{print $1}'` + if [ "${md5_file}" != "${md5_file_ok}" ]; then + echo "keepalived-${version} 下载文件不完整,重新安装" + rm -rf $serverPath/source/keepalived/keepalived-${VERSION}.tar.gz + fi + fi + + echo $serverPath/keepalived/keepalived-${VERSION} + if [ -d $serverPath/keepalived/keepalived-${VERSION} ];then + cd $serverPath/keepalived/keepalived-${VERSION} + else + cd $serverPath/source/keepalived && tar -zxvf keepalived-${VERSION}.tar.gz + cd $serverPath/keepalived/keepalived-${VERSION} + fi + + cd $serverPath/source/keepalived/keepalived-${VERSION} + + ./configure --prefix=$serverPath/keepalived && make && make install + + if [ -d $serverPath/keepalived ];then + echo "${VERSION}" > $serverPath/keepalived/version.pl + echo '安装完成' > $install_tmp + + cd ${rootPath} && python3 ${rootPath}/plugins/keepalived/index.py start + cd ${rootPath} && python3 ${rootPath}/plugins/keepalived/index.py initd_install + fi +} + +Uninstall_App() +{ + if [ -f /usr/lib/systemd/system/keepalived.service ];then + systemctl stop keepalived + systemctl disable keepalived + rm -rf /usr/lib/systemd/system/keepalived.service + systemctl daemon-reload + fi + + if [ -f $serverPath/keepalived/initd/keepalived ];then + $serverPath/keepalived/initd/keepalived stop + fi + + rm -rf $serverPath/keepalived + echo "uninstall_keepalived" > $install_tmp +} + +action=$1 +if [ "${1}" == 'install' ];then + Install_App +else + Uninstall_App +fi diff --git a/plugins/keepalived/js/keepalived.js b/plugins/keepalived/js/keepalived.js new file mode 100755 index 000000000..31c4ea19b --- /dev/null +++ b/plugins/keepalived/js/keepalived.js @@ -0,0 +1,143 @@ +function redisPost(method, version, args,callback){ + var loadT = layer.msg('正在获取...', { icon: 16, time: 0, shade: 0.3 }); + + var req_data = {}; + req_data['name'] = 'keepalived'; + req_data['func'] = method; + req_data['version'] = version; + + if (typeof(args) == 'string'){ + req_data['args'] = JSON.stringify(toArrayObject(args)); + } else { + req_data['args'] = JSON.stringify(args); + } + + $.post('/plugins/run', req_data, function(data) { + layer.close(loadT); + if (!data.status){ + //错误展示10S + layer.msg(data.msg,{icon:0,time:2000,shade: [10, '#000']}); + return; + } + + if(typeof(callback) == 'function'){ + callback(data); + } + },'json'); +} + +function redisPostCallbak(method, version, args,callback){ + var loadT = layer.msg('正在获取...', { icon: 16, time: 0, shade: 0.3 }); + + var req_data = {}; + req_data['name'] = 'keepalived'; + req_data['func'] = method; + args['version'] = version; + + if (typeof(args) == 'string'){ + req_data['args'] = JSON.stringify(toArrayObject(args)); + } else { + req_data['args'] = JSON.stringify(args); + } + + $.post('/plugins/callback', req_data, function(data) { + layer.close(loadT); + if (!data.status){ + layer.msg(data.msg,{icon:0,time:2000,shade: [0.3, '#000']}); + return; + } + + if(typeof(callback) == 'function'){ + callback(data); + } + },'json'); +} + +//redis负载状态 start +function redisStatus(version) { + + redisPost('run_info',version, {},function(data){ + var rdata = $.parseJSON(data.data); + // if (!rdata.status){ + // layer.msg(data.msg,{icon:0,time:2000,shade: [0.3, '#000']}); + // return; + // } + + hit = (parseInt(rdata.keyspace_hits) / (parseInt(rdata.keyspace_hits) + parseInt(rdata.keyspace_misses)) * 100).toFixed(2); + var con = '
\ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ +
字段当前值说明
uptime_in_days' + rdata.uptime_in_days + '已运行天数
tcp_port' + rdata.tcp_port + '当前监听端口
connected_clients' + rdata.connected_clients + '连接的客户端数量
used_memory_rss' + toSize(rdata.used_memory_rss) + 'Redis当前占用的系统内存总量
used_memory' + toSize(rdata.used_memory) + 'Redis当前已分配的内存总量
used_memory_peak' + toSize(rdata.used_memory_peak) + 'Redis历史分配内存的峰值
mem_fragmentation_ratio' + rdata.mem_fragmentation_ratio + '%内存碎片比率
total_connections_received' + rdata.total_connections_received + '运行以来连接过的客户端的总数量
total_commands_processed' + rdata.total_commands_processed + '运行以来执行过的命令的总数量
instantaneous_ops_per_sec' + rdata.instantaneous_ops_per_sec + '服务器每秒钟执行的命令数量
keyspace_hits' + rdata.keyspace_hits + '查找数据库键成功的次数
keyspace_misses' + rdata.keyspace_misses + '查找数据库键失败的次数
hit' + hit + '%查找数据库键命中率
latest_fork_usec' + rdata.latest_fork_usec + '最近一次 fork() 操作耗费的微秒数
'; + $(".soft-man-con").html(con); + }); +} +//redis负载状态 end + +//配置修改 +function getRedisConfig(version) { + redisPost('get_redis_conf', version,'',function(data){ + // console.log(data); + var rdata = $.parseJSON(data.data); + // console.log(rdata); + var mlist = ''; + for (var i = 0; i < rdata.length; i++) { + var w = '70' + if (rdata[i].name == 'error_reporting') w = '250'; + var ibody = ''; + switch (rdata[i].type) { + case 0: + var selected_1 = (rdata[i].value == 1) ? 'selected' : ''; + var selected_0 = (rdata[i].value == 0) ? 'selected' : ''; + ibody = '' + break; + case 1: + var selected_1 = (rdata[i].value == 'On') ? 'selected' : ''; + var selected_0 = (rdata[i].value == 'Off') ? 'selected' : ''; + ibody = '' + break; + } + mlist += '

' + rdata[i].name + '' + ibody + ', ' + rdata[i].ps + '

' + } + var con = '
' + mlist + '\ +
\ +
\ +
' + $(".soft-man-con").html(con); + }); +} + +//提交配置 +function submitConf(version) { + var data = { + version: version, + bind: $("input[name='bind']").val(), + 'port': $("input[name='port']").val(), + 'timeout': $("input[name='timeout']").val(), + maxclients: $("input[name='maxclients']").val(), + databases: $("input[name='databases']").val(), + requirepass: $("input[name='requirepass']").val(), + maxmemory: $("input[name='maxmemory']").val(), + }; + + redisPost('submit_redis_conf', version, data, function(ret_data){ + var rdata = $.parseJSON(ret_data.data); + layer.msg(rdata.msg, { icon: rdata.status ? 1 : 2 }); + }); +} +