mirror of https://github.com/midoks/mdserver-web
parent
52bad278cc
commit
6582cbc09d
@ -1,57 +0,0 @@ |
|||||||
# # Global variables are applied to all deployments and used as the default value of |
|
||||||
# # the deployments if a specific deployment value is missing. |
|
||||||
global: |
|
||||||
user: "tidb" |
|
||||||
ssh_port: 2022 |
|
||||||
deploy_dir: "/home/tidb/tidb-deploy" |
|
||||||
data_dir: "/home/tidb/tidb-data" |
|
||||||
|
|
||||||
# # Monitored variables are applied to all the machines. |
|
||||||
monitored: |
|
||||||
node_exporter_port: 9100 |
|
||||||
blackbox_exporter_port: 9115 |
|
||||||
|
|
||||||
server_configs: |
|
||||||
tidb: |
|
||||||
instance.tidb_slow_log_threshold: 300 |
|
||||||
tikv: |
|
||||||
readpool.storage.use-unified-pool: false |
|
||||||
readpool.coprocessor.use-unified-pool: true |
|
||||||
pd: |
|
||||||
replication.enable-placement-rules: true |
|
||||||
replication.location-labels: ["host"] |
|
||||||
tiflash: |
|
||||||
logger.level: "info" |
|
||||||
|
|
||||||
pd_servers: |
|
||||||
- host: 192.168.4.1 |
|
||||||
|
|
||||||
tidb_servers: |
|
||||||
- host: 192.168.4.1 |
|
||||||
|
|
||||||
tikv_servers: |
|
||||||
port: 20160 |
|
||||||
status_port: 20180 |
|
||||||
config: |
|
||||||
server.labels: { host: "logic-host-1" } |
|
||||||
|
|
||||||
- host: 192.168.4.1 |
|
||||||
port: 20161 |
|
||||||
status_port: 20181 |
|
||||||
config: |
|
||||||
server.labels: { host: "logic-host-2" } |
|
||||||
|
|
||||||
- host: 192.168.4.1 |
|
||||||
port: 20162 |
|
||||||
status_port: 20182 |
|
||||||
config: |
|
||||||
server.labels: { host: "logic-host-3" } |
|
||||||
|
|
||||||
tiflash_servers: |
|
||||||
- host: 192.168.4.1 |
|
||||||
|
|
||||||
monitoring_servers: |
|
||||||
- host: 192.168.4.1 |
|
||||||
|
|
||||||
grafana_servers: |
|
||||||
- host: 192.168.4.1 |
|
@ -1,46 +0,0 @@ |
|||||||
# # Global variables are applied to all deployments and used as the default value of |
|
||||||
# # the deployments if a specific deployment value is missing. |
|
||||||
global: |
|
||||||
user: "root" |
|
||||||
ssh_port: 2022 |
|
||||||
deploy_dir: "/tidb/tidb-deploy" |
|
||||||
data_dir: "/tidb/tidb-data" |
|
||||||
|
|
||||||
# # Monitored variables are applied to all the machines. |
|
||||||
monitored: |
|
||||||
node_exporter_port: 9100 |
|
||||||
blackbox_exporter_port: 9115 |
|
||||||
|
|
||||||
server_configs: |
|
||||||
tidb: |
|
||||||
instance.tidb_slow_log_threshold: 300 |
|
||||||
tikv: |
|
||||||
readpool.storage.use-unified-pool: false |
|
||||||
readpool.coprocessor.use-unified-pool: true |
|
||||||
pd: |
|
||||||
replication.enable-placement-rules: true |
|
||||||
replication.location-labels: ["host"] |
|
||||||
tiflash: |
|
||||||
logger.level: "info" |
|
||||||
|
|
||||||
pd_servers: |
|
||||||
- host: 154.21.203.138 |
|
||||||
|
|
||||||
tidb_servers: |
|
||||||
- host: 154.21.203.138 |
|
||||||
|
|
||||||
tikv_servers: |
|
||||||
- host: 154.21.203.138 |
|
||||||
port: 20160 |
|
||||||
status_port: 20180 |
|
||||||
config: |
|
||||||
server.labels: { host: "logic-host-1" } |
|
||||||
|
|
||||||
tiflash_servers: |
|
||||||
- host: 154.21.203.138 |
|
||||||
|
|
||||||
monitoring_servers: |
|
||||||
- host: 154.21.203.138 |
|
||||||
|
|
||||||
grafana_servers: |
|
||||||
- host: 154.21.203.138 |
|
Before Width: | Height: | Size: 5.8 KiB |
@ -1,35 +0,0 @@ |
|||||||
<style> |
|
||||||
.overflow_hide { |
|
||||||
overflow: hidden; |
|
||||||
text-overflow: ellipsis; |
|
||||||
white-space: nowrap; |
|
||||||
vertical-align: middle; |
|
||||||
} |
|
||||||
</style> |
|
||||||
|
|
||||||
<div class="bt-form"> |
|
||||||
<div class='plugin_version'></div> |
|
||||||
<div class="bt-w-main"> |
|
||||||
<div class="bt-w-menu"> |
|
||||||
<p class="bgw" onclick="pluginService('tidb');">服务</p> |
|
||||||
<p onclick="pluginInitD('tidb');">自启动</p> |
|
||||||
<p onclick="pluginConfigTpl('tidb',$('.plugin_version').attr('version'));">配置修改</p> |
|
||||||
<!-- <p onclick="pluginConfig('redis');">配置修改</p> --> |
|
||||||
<p onclick="getRedisConfig($('.plugin_version').attr('version'));">性能调整</p> |
|
||||||
<p onclick="redisStatus($('.plugin_version').attr('version'));">负载状态</p> |
|
||||||
<p onclick="replStatus($('.plugin_version').attr('version'));">复制状态</p> |
|
||||||
<p onclick="clusterStatus($('.plugin_version').attr('version'));">集群状态</p> |
|
||||||
<p onclick="clusterNodes($('.plugin_version').attr('version'));">集群节点</p> |
|
||||||
<p onclick="pluginLogs('tidb','','run_log');">运行日志</p> |
|
||||||
<p onclick="tidbReadme();">相关说明</p> |
|
||||||
</div> |
|
||||||
<div class="bt-w-con pd15"> |
|
||||||
<div class="soft-man-con" style="height: 520px; overflow: auto;"></div> |
|
||||||
</div> |
|
||||||
</div> |
|
||||||
</div> |
|
||||||
<script type="text/javascript"> |
|
||||||
$.getScript( "/plugins/file?name=tidb&f=js/tidb.js", function(){ |
|
||||||
pluginService('tidb', $('.plugin_version').attr('version')); |
|
||||||
}); |
|
||||||
</script> |
|
@ -1,584 +0,0 @@ |
|||||||
# 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 'tidb' |
|
||||||
|
|
||||||
|
|
||||||
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() + "/tidb.conf" |
|
||||||
return path |
|
||||||
|
|
||||||
|
|
||||||
def getConfTpl(): |
|
||||||
path = getPluginDir() + "/conf/tidb.conf" |
|
||||||
return path |
|
||||||
|
|
||||||
|
|
||||||
def getInitDTpl(): |
|
||||||
path = getPluginDir() + "/init.d/" + getPluginName() + ".tpl" |
|
||||||
return path |
|
||||||
|
|
||||||
def getArgs(): |
|
||||||
args = sys.argv[2:] |
|
||||||
tmp = {} |
|
||||||
args_len = len(args) |
|
||||||
|
|
||||||
if args_len == 1: |
|
||||||
t = args[0].strip('{').strip('}') |
|
||||||
t = t.split(':', 1) |
|
||||||
tmp[t[0]] = t[1] |
|
||||||
elif args_len > 1: |
|
||||||
for i in range(len(args)): |
|
||||||
t = args[i].split(':', 1) |
|
||||||
tmp[t[0]] = t[1] |
|
||||||
return tmp |
|
||||||
|
|
||||||
def getArgsBk(): |
|
||||||
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 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 configTpl(): |
|
||||||
path = getPluginDir() + '/tpl' |
|
||||||
pathFile = os.listdir(path) |
|
||||||
tmp = [] |
|
||||||
for one in pathFile: |
|
||||||
file = path + '/' + one |
|
||||||
tmp.append(file) |
|
||||||
return mw.getJson(tmp) |
|
||||||
|
|
||||||
|
|
||||||
def readConfigTpl(): |
|
||||||
args = getArgs() |
|
||||||
data = checkArgs(args, ['file']) |
|
||||||
if not data[0]: |
|
||||||
return data[1] |
|
||||||
|
|
||||||
content = mw.readFile(args['file']) |
|
||||||
content = contentReplace(content) |
|
||||||
return mw.returnJson(True, 'ok', content) |
|
||||||
|
|
||||||
def getPidFile(): |
|
||||||
file = getConf() |
|
||||||
content = mw.readFile(file) |
|
||||||
rep = 'pidfile\s*(.*)' |
|
||||||
tmp = re.search(rep, content) |
|
||||||
return tmp.groups()[0].strip() |
|
||||||
|
|
||||||
def status(): |
|
||||||
# pid_file = getPidFile() |
|
||||||
# if not os.path.exists(pid_file): |
|
||||||
# return 'stop' |
|
||||||
|
|
||||||
# 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 'stop' |
|
||||||
|
|
||||||
def contentReplace(content): |
|
||||||
service_path = mw.getServerDir() |
|
||||||
content = content.replace('{$ROOT_PATH}', mw.getRootDir()) |
|
||||||
content = content.replace('{$SERVER_PATH}', service_path) |
|
||||||
content = content.replace('{$SERVER_APP}', service_path + '/redis') |
|
||||||
content = content.replace('{$REDIS_PASS}', mw.getRandomString(10)) |
|
||||||
return content |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
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) |
|
||||||
|
|
||||||
|
|
||||||
conf_list = ['tidb.conf', 'tidb.yaml'] |
|
||||||
dst_conf_init = getServerDir() + '/init.pl' |
|
||||||
if not os.path.exists(dst_conf_init): |
|
||||||
for conf in conf_list: |
|
||||||
dst_conf = getServerDir() + '/'+ conf |
|
||||||
src_conf = getPluginDir() + '/conf/'+ conf |
|
||||||
if not os.path.exists(dst_conf): |
|
||||||
content = mw.readFile(src_conf) |
|
||||||
content = content.replace('{$SERVER_PATH}', service_path) |
|
||||||
mw.writeFile(dst_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 tiOp(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 + ' ' + getPluginName()) |
|
||||||
if data[1] == '': |
|
||||||
return 'ok' |
|
||||||
return data[1] |
|
||||||
|
|
||||||
|
|
||||||
def start(): |
|
||||||
return tiOp('start') |
|
||||||
|
|
||||||
|
|
||||||
def stop(): |
|
||||||
return tiOp('stop') |
|
||||||
|
|
||||||
|
|
||||||
def restart(): |
|
||||||
status = tiOp('restart') |
|
||||||
return status |
|
||||||
|
|
||||||
|
|
||||||
def reload(): |
|
||||||
return tiOp('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 getRedisCmd(): |
|
||||||
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 + " " |
|
||||||
|
|
||||||
if requirepass != "": |
|
||||||
cmd = getServerDir() + '/bin/redis-cli -h ' + default_ip + \ |
|
||||||
' -p ' + port + ' -a "' + requirepass + '" ' |
|
||||||
|
|
||||||
return cmd |
|
||||||
|
|
||||||
def runInfo(): |
|
||||||
s = status() |
|
||||||
if s == 'stop': |
|
||||||
return mw.returnJson(False, '未启动') |
|
||||||
|
|
||||||
|
|
||||||
cmd = getRedisCmd() |
|
||||||
cmd = cmd + 'info' |
|
||||||
|
|
||||||
# print(cmd) |
|
||||||
data = mw.execShell(cmd)[0] |
|
||||||
# print(data) |
|
||||||
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 infoReplication(): |
|
||||||
# 复制信息 |
|
||||||
s = status() |
|
||||||
if s == 'stop': |
|
||||||
return mw.returnJson(False, '未启动') |
|
||||||
|
|
||||||
cmd = getRedisCmd() |
|
||||||
cmd = cmd + 'info replication' |
|
||||||
|
|
||||||
# print(cmd) |
|
||||||
data = mw.execShell(cmd)[0] |
|
||||||
# print(data) |
|
||||||
res = [ |
|
||||||
#slave |
|
||||||
'role',#角色 |
|
||||||
'master_host', # 连接主库HOST |
|
||||||
'master_port', # 连接主库PORT |
|
||||||
'master_link_status', # 连接主库状态 |
|
||||||
'master_last_io_seconds_ago', # 上次同步时间 |
|
||||||
'master_sync_in_progress', # 正在同步中 |
|
||||||
'slave_read_repl_offset', # 从库读取复制位置 |
|
||||||
'slave_repl_offset', # 从库复制位置 |
|
||||||
'slave_priority', # 从库同步优先级 |
|
||||||
'slave_read_only', # 从库是否仅读 |
|
||||||
'replica_announced', # 已复制副本 |
|
||||||
'connected_slaves', # 连接从库数量 |
|
||||||
'master_failover_state', # 主库故障状态 |
|
||||||
'master_replid', # 主库复制ID |
|
||||||
'master_repl_offset', # 主库复制位置 |
|
||||||
'second_repl_offset', # 主库复制位置时间 |
|
||||||
'repl_backlog_active', # 复制状态 |
|
||||||
'repl_backlog_size', # 复制大小 |
|
||||||
'repl_backlog_first_byte_offset', # 第一个字节偏移量 |
|
||||||
'repl_backlog_histlen', # backlog中数据的长度 |
|
||||||
] |
|
||||||
|
|
||||||
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] |
|
||||||
|
|
||||||
if 'role' in result and result['role'] == 'master': |
|
||||||
connected_slaves = int(result['connected_slaves']) |
|
||||||
slave_l = [] |
|
||||||
for x in range(connected_slaves): |
|
||||||
slave_l.append('slave'+str(x)) |
|
||||||
|
|
||||||
for d in data: |
|
||||||
if len(d) < 3: |
|
||||||
continue |
|
||||||
t = d.strip().split(':') |
|
||||||
if not t[0] in slave_l: |
|
||||||
continue |
|
||||||
result[t[0]] = t[1] |
|
||||||
|
|
||||||
return mw.getJson(result) |
|
||||||
|
|
||||||
|
|
||||||
def clusterInfo(): |
|
||||||
#集群信息 |
|
||||||
# https://redis.io/commands/cluster-info/ |
|
||||||
s = status() |
|
||||||
if s == 'stop': |
|
||||||
return mw.returnJson(False, '未启动') |
|
||||||
|
|
||||||
cmd = getRedisCmd() |
|
||||||
cmd = cmd + 'cluster info' |
|
||||||
|
|
||||||
# print(cmd) |
|
||||||
data = mw.execShell(cmd)[0] |
|
||||||
# print(data) |
|
||||||
|
|
||||||
res = [ |
|
||||||
'cluster_state',#状态 |
|
||||||
'cluster_slots_assigned', # 被分配的槽 |
|
||||||
'cluster_slots_ok', # 被分配的槽状态 |
|
||||||
'cluster_slots_pfail', # 连接主库状态 |
|
||||||
'cluster_slots_fail', # 失败的槽 |
|
||||||
'cluster_known_nodes', # 知道的节点 |
|
||||||
'cluster_size', # 大小 |
|
||||||
'cluster_current_epoch', # |
|
||||||
'cluster_my_epoch', # |
|
||||||
'cluster_stats_messages_sent', # 发送 |
|
||||||
'cluster_stats_messages_received', # 接受 |
|
||||||
'total_cluster_links_buffer_limit_exceeded', # |
|
||||||
] |
|
||||||
|
|
||||||
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 clusterNodes(): |
|
||||||
s = status() |
|
||||||
if s == 'stop': |
|
||||||
return mw.returnJson(False, '未启动') |
|
||||||
|
|
||||||
cmd = getRedisCmd() |
|
||||||
cmd = cmd + 'cluster nodes' |
|
||||||
|
|
||||||
# print(cmd) |
|
||||||
data = mw.execShell(cmd)[0] |
|
||||||
# print(data) |
|
||||||
|
|
||||||
data = data.strip().split("\n") |
|
||||||
return mw.getJson(data) |
|
||||||
|
|
||||||
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可能会存在安全隐患)','must_show':1}, |
|
||||||
{'name': 'port', 'type': 2, 'ps': '绑定端口','must_show':1}, |
|
||||||
{'name': 'timeout', 'type': 2, 'ps': '空闲链接超时时间,0表示不断开','must_show':1}, |
|
||||||
{'name': 'maxclients', 'type': 2, 'ps': '最大连接数','must_show':1}, |
|
||||||
{'name': 'databases', 'type': 2, 'ps': '数据库数量','must_show':1}, |
|
||||||
{'name': 'requirepass', 'type': 2, 'ps': 'redis密码,留空代表没有设置密码','must_show':1}, |
|
||||||
{'name': 'maxmemory', 'type': 2, 'ps': 'MB,最大使用内存,0表示不限制','must_show':1}, |
|
||||||
{'name': 'slaveof', 'type': 2, 'ps': '同步主库地址','must_show':0}, |
|
||||||
{'name': 'masterauth', 'type': 2, 'ps': '同步主库密码', 'must_show':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: |
|
||||||
if g['must_show'] == 0: |
|
||||||
continue |
|
||||||
|
|
||||||
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','slaveof','masterauth'] |
|
||||||
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 == 'info_replication': |
|
||||||
print(infoReplication()) |
|
||||||
elif func == 'cluster_info': |
|
||||||
print(clusterInfo()) |
|
||||||
elif func == 'cluster_nodes': |
|
||||||
print(clusterNodes()) |
|
||||||
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()) |
|
||||||
elif func == 'config_tpl': |
|
||||||
print(configTpl()) |
|
||||||
elif func == 'read_config_tpl': |
|
||||||
print(readConfigTpl()) |
|
||||||
else: |
|
||||||
print('error') |
|
@ -1,17 +0,0 @@ |
|||||||
{ |
|
||||||
"sort": 10, |
|
||||||
"ps": "分布式数据库(高度兼容MySQL)[社区版][<span style='color:red;'>暂时不可用</span>]", |
|
||||||
"name": "tidb", |
|
||||||
"title": "TiDB", |
|
||||||
"shell": "install.sh", |
|
||||||
"versions":["v7.5.1","v8.0.0"], |
|
||||||
"tip": "soft", |
|
||||||
"checks": "server/tidb", |
|
||||||
"path": "server/tidb", |
|
||||||
"display": 1, |
|
||||||
"author": "tidb", |
|
||||||
"date": "2024-05-11", |
|
||||||
"home": "https://cn.pingcap.com/product-community/", |
|
||||||
"type": 0, |
|
||||||
"pid": "2" |
|
||||||
} |
|
@ -1,12 +0,0 @@ |
|||||||
[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 |
|
@ -1,77 +0,0 @@ |
|||||||
#!/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 |
|
||||||
|
|
||||||
echo $REDISPASS |
|
||||||
echo $REDISPORT |
|
||||||
echo $CLIEXEC |
|
||||||
|
|
||||||
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 save 2>/dev/null |
|
||||||
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 |
|
||||||
|
|
@ -1,124 +0,0 @@ |
|||||||
#!/bin/bash |
|
||||||
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin:/opt/homebrew/bin |
|
||||||
export PATH |
|
||||||
|
|
||||||
curPath=`pwd` |
|
||||||
rootPath=$(dirname "$curPath") |
|
||||||
rootPath=$(dirname "$rootPath") |
|
||||||
serverPath=$(dirname "$rootPath") |
|
||||||
|
|
||||||
sysName=`uname` |
|
||||||
sysArch=`arch` |
|
||||||
echo "use system: ${sysName}" |
|
||||||
|
|
||||||
# https://cn.pingcap.com/product-community/ |
|
||||||
# https://docs.pingcap.com/zh/tidb/stable/quick-start-with-tidb |
|
||||||
|
|
||||||
# cd /Users/midoks/Desktop/mwdev/server/mdserver-web/plugins/tidb && bash install.sh install v7.5.1 |
|
||||||
# mw update_dev && cd /www/server/mdserver-web/plugins/tidb && bash install.sh install v7.5.1 |
|
||||||
# python3 /www/server/mdserver-web/plugins/tidb/index.py start |
|
||||||
# cd /www/server/source/tidb/tidb-community-server-v7.5.1-linux-amd64 && ./local_install.sh |
|
||||||
# cd /www/server/tidb/mirror && ./local_install.sh |
|
||||||
# source /root/.bashrc |
|
||||||
|
|
||||||
# ssh 192.168.4.1 -l root |
|
||||||
# useradd -d /home/tidb1 tidb1 && passwd tidb1 |
|
||||||
|
|
||||||
# tidb ssh |
|
||||||
# /root/.tiup/storage/cluster/clusters/tidb/ssh |
|
||||||
|
|
||||||
# ssh-copy-id -p 2022 root@154.21.203.138 |
|
||||||
# ssh -p 2022 root@154.21.203.138 -i /root/.tiup/storage/cluster/clusters/tidb/ssh/id_rsa |
|
||||||
|
|
||||||
# grafana |
|
||||||
# http://154.21.203.138:3000 |
|
||||||
|
|
||||||
# grafana |
|
||||||
# http://154.21.203.138:3000 |
|
||||||
|
|
||||||
# rm -rf /root/.tiup |
|
||||||
# tiup cluster deploy tidb v7.5.1 /www/server/tidb/tidb.yaml --user root -p |
|
||||||
# tiup cluster deploy mw v7.5.1 /www/server/tidb/tidb.yaml --user root -p |
|
||||||
|
|
||||||
# tiup cluster clean tidb --all |
|
||||||
# tiup cluster display tidb |
|
||||||
# tiup cluster destroy tidb |
|
||||||
|
|
||||||
# tiup cluster clean tidb --all --ignore-role prometheus grafana |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
install_tmp=${rootPath}/tmp/mw_install.pl |
|
||||||
VERSION=$2 |
|
||||||
TIDB_ARCH=arm64 |
|
||||||
if [ "$sysArch" == "x86_64" ];then |
|
||||||
TIDB_ARCH=amd64 |
|
||||||
fi |
|
||||||
|
|
||||||
if [ "$sysArch" == "aarch64" ];then |
|
||||||
TIDB_ARCH=arm64 |
|
||||||
fi |
|
||||||
|
|
||||||
Install_App() |
|
||||||
{ |
|
||||||
echo '正在安装脚本文件...' > $install_tmp |
|
||||||
mkdir -p $serverPath/source |
|
||||||
mkdir -p $serverPath/source/tidb |
|
||||||
|
|
||||||
tidb_name=tidb-community-server-${VERSION}-linux-${TIDB_ARCH} |
|
||||||
tidb_toolkit_name=tidb-community-toolkit-${VERSION}-linux-${TIDB_ARCH} |
|
||||||
tgz_name=${tidb_name}.tar.gz |
|
||||||
tgz_toolkit_name=${tidb_toolkit_name}.tar.gz |
|
||||||
|
|
||||||
|
|
||||||
if [ ! -f $serverPath/source/tidb/${tgz_name} ];then |
|
||||||
wget -O $serverPath/source/tidb/${tgz_name} https://download.pingcap.org/${tgz_name} |
|
||||||
fi |
|
||||||
|
|
||||||
|
|
||||||
if [ ! -d $serverPath/source/tidb/${tidb_name} ];then |
|
||||||
cd $serverPath/source/tidb && tar -zxvf $serverPath/source/tidb/${tgz_name} |
|
||||||
fi |
|
||||||
|
|
||||||
if [ ! -f $serverPath/source/tidb/${tgz_toolkit_name} ];then |
|
||||||
wget -O $serverPath/source/tidb/${tgz_toolkit_name} https://download.pingcap.org/${tgz_toolkit_name} |
|
||||||
fi |
|
||||||
|
|
||||||
if [ ! -d $serverPath/source/tidb/${tgz_toolkit_name} ];then |
|
||||||
cd $serverPath/source/tidb && tar -zxvf $serverPath/source/tidb/${tgz_toolkit_name} |
|
||||||
fi |
|
||||||
|
|
||||||
if [ ! -d $serverPath/tidb/mirror ];then |
|
||||||
mkdir -p $serverPath/tidb/mirror |
|
||||||
cp -rf $serverPath/source/tidb/${tidb_name}/* $serverPath/tidb/mirror |
|
||||||
fi |
|
||||||
|
|
||||||
cd $serverPath/tidb/mirror && ./local_install.sh |
|
||||||
|
|
||||||
if [ -d $serverPath/tidb ];then |
|
||||||
echo "${VERSION}" > $serverPath/tidb/version.pl |
|
||||||
|
|
||||||
cd ${rootPath} && python3 ${rootPath}/plugins/tidb/index.py start |
|
||||||
# cd ${rootPath} && python3 ${rootPath}/plugins/tidb/index.py initd_install |
|
||||||
echo '安装完成' |
|
||||||
else |
|
||||||
echo '安装失败!' |
|
||||||
fi |
|
||||||
|
|
||||||
if [ -d $serverPath/source/redis-${VERSION} ];then |
|
||||||
rm -rf $serverPath/source/redis-${VERSION} |
|
||||||
fi |
|
||||||
} |
|
||||||
|
|
||||||
Uninstall_App() |
|
||||||
{ |
|
||||||
rm -rf $serverPath/tidb |
|
||||||
echo "卸载TiDB" |
|
||||||
} |
|
||||||
|
|
||||||
action=$1 |
|
||||||
if [ "${1}" == 'install' ];then |
|
||||||
Install_App |
|
||||||
else |
|
||||||
Uninstall_App |
|
||||||
fi |
|
@ -1,297 +0,0 @@ |
|||||||
function tiPost(method, version, args,callback){ |
|
||||||
var loadT = layer.msg('正在获取...', { icon: 16, time: 0, shade: 0.3 }); |
|
||||||
|
|
||||||
var req_data = {}; |
|
||||||
req_data['name'] = 'redis'; |
|
||||||
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'] = 'redis'; |
|
||||||
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 ('status' in rdata && !rdata.status){ |
|
||||||
layer.msg(rdata.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 = '<div class="divtable">\ |
|
||||||
<table class="table table-hover table-bordered" style="width: 490px;">\ |
|
||||||
<thead><th>字段</th><th>当前值</th><th>说明</th></thead>\ |
|
||||||
<tbody>\ |
|
||||||
<tr><th>uptime_in_days</th><td>' + rdata.uptime_in_days + '</td><td>已运行天数</td></tr>\ |
|
||||||
<tr><th>tcp_port</th><td>' + rdata.tcp_port + '</td><td>当前监听端口</td></tr>\ |
|
||||||
<tr><th>connected_clients</th><td>' + rdata.connected_clients + '</td><td>连接的客户端数量</td></tr>\ |
|
||||||
<tr><th>used_memory_rss</th><td>' + toSize(rdata.used_memory_rss) + '</td><td>Redis当前占用的系统内存总量</td></tr>\ |
|
||||||
<tr><th>used_memory</th><td>' + toSize(rdata.used_memory) + '</td><td>Redis当前已分配的内存总量</td></tr>\ |
|
||||||
<tr><th>used_memory_peak</th><td>' + toSize(rdata.used_memory_peak) + '</td><td>Redis历史分配内存的峰值</td></tr>\ |
|
||||||
<tr><th>mem_fragmentation_ratio</th><td>' + rdata.mem_fragmentation_ratio + '%</td><td>内存碎片比率</td></tr>\ |
|
||||||
<tr><th>total_connections_received</th><td>' + rdata.total_connections_received + '</td><td>运行以来连接过的客户端的总数量</td></tr>\ |
|
||||||
<tr><th>total_commands_processed</th><td>' + rdata.total_commands_processed + '</td><td>运行以来执行过的命令的总数量</td></tr>\ |
|
||||||
<tr><th>instantaneous_ops_per_sec</th><td>' + rdata.instantaneous_ops_per_sec + '</td><td>服务器每秒钟执行的命令数量</td></tr>\ |
|
||||||
<tr><th>keyspace_hits</th><td>' + rdata.keyspace_hits + '</td><td>查找数据库键成功的次数</td></tr>\ |
|
||||||
<tr><th>keyspace_misses</th><td>' + rdata.keyspace_misses + '</td><td>查找数据库键失败的次数</td></tr>\ |
|
||||||
<tr><th>hit</th><td>' + hit + '%</td><td>查找数据库键命中率</td></tr>\ |
|
||||||
<tr><th>latest_fork_usec</th><td>' + rdata.latest_fork_usec + '</td><td>最近一次 fork() 操作耗费的微秒数</td></tr>\ |
|
||||||
<tbody>\ |
|
||||||
</table></div>'; |
|
||||||
$(".soft-man-con").html(con); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
function replStatus(version){ |
|
||||||
redisPost('info_replication', version, {},function(data){ |
|
||||||
var rdata = $.parseJSON(data.data); |
|
||||||
|
|
||||||
if ('status' in rdata && !rdata.status){ |
|
||||||
layer.msg(rdata.msg,{icon:0,time:2000,shade: [0.3, '#000']}); |
|
||||||
return; |
|
||||||
} |
|
||||||
|
|
||||||
var kv = { |
|
||||||
'role':'角色', |
|
||||||
'master_host':'连接主库HOST', |
|
||||||
'master_port':'连接主库PORT', |
|
||||||
'master_link_status':'连接主库状态', |
|
||||||
'master_last_io_seconds_ago':'上次同步时间', |
|
||||||
'master_sync_in_progress':'正在同步中', |
|
||||||
'slave_read_repl_offset':'从库读取复制位置', |
|
||||||
'slave_repl_offset':'从库复制位置', |
|
||||||
'slave_read_only':'从库是否仅读', |
|
||||||
'replica_announced':'已复制副本', |
|
||||||
'connected_slaves':'连接数量', |
|
||||||
'master_failover_state':'主库故障状态', |
|
||||||
'master_replid':'主库复制ID', |
|
||||||
'master_repl_offset':'主库复制位置', |
|
||||||
'repl_backlog_size':'backlog复制大小', |
|
||||||
'second_repl_offset':'复制位置时间', |
|
||||||
'repl_backlog_first_byte_offset':'第一个字节偏移量', |
|
||||||
'repl_backlog_histlen':'backlog中数据的长度', |
|
||||||
'repl_backlog_active':'开启复制缓冲区', |
|
||||||
'slave_priority':'同步优先级', |
|
||||||
} |
|
||||||
|
|
||||||
var tbody_text = ''; |
|
||||||
for (k in rdata){ |
|
||||||
if (k == 'master_replid'){ |
|
||||||
tbody_text += '<tr><th>'+k+'</th><td class="overflow_hide" style="width:155px;display: inline-block;border: none;">' + rdata[k] + '</td><td>'+kv[k]+'</td></tr>'; |
|
||||||
} else{ |
|
||||||
|
|
||||||
if (k.substring(0,5) == 'slave' && !isNaN(k.substring(5))){ |
|
||||||
tbody_text += '<tr><th>'+k+'</th><td class="overflow_hide" style="width:155px;display: inline-block;border: none;" title="'+rdata[k]+'">' + rdata[k] + '</td><td>从库配置信息</td></tr>'; |
|
||||||
} else{ |
|
||||||
tbody_text += '<tr><th>'+k+'</th><td>' + rdata[k] + '</td><td>'+kv[k]+'</td></tr>'; |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
} |
|
||||||
|
|
||||||
var con = '<div class="divtable">\ |
|
||||||
<table class="table table-hover table-bordered" style="width: 490px;">\ |
|
||||||
<thead><th style="width:80px;">字段</th><th style="width:90px;">当前值</th><th>说明</th></thead>\ |
|
||||||
<tbody>'+tbody_text+'<tbody>\ |
|
||||||
</table></div>'; |
|
||||||
$(".soft-man-con").html(con); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
function clusterStatus(version){ |
|
||||||
redisPost('cluster_info', version, {},function(data){ |
|
||||||
var rdata = $.parseJSON(data.data); |
|
||||||
|
|
||||||
if ('status' in rdata && !rdata.status){ |
|
||||||
layer.msg(rdata.msg,{icon:0,time:2000,shade: [0.3, '#000']}); |
|
||||||
return; |
|
||||||
} |
|
||||||
|
|
||||||
var kv = { |
|
||||||
'cluster_state':'集群状态', |
|
||||||
'cluster_slots_assigned':'被分配的槽', |
|
||||||
'cluster_slots_ok':'被分配的槽状态', |
|
||||||
'cluster_known_nodes':'知道的节点', |
|
||||||
'cluster_size':'大小', |
|
||||||
'cluster_stats_messages_sent':'发送', |
|
||||||
'cluster_stats_messages_received':'接收', |
|
||||||
'cluster_current_epoch':'集群当前epoch', |
|
||||||
'cluster_my_epoch':'当前我的epoch', |
|
||||||
'cluster_slots_pfail':'处于PFAIL状态的槽数', |
|
||||||
'cluster_slots_fail':'处于FAIL状态的槽数', |
|
||||||
'total_cluster_links_buffer_limit_exceeded':'超出缓冲区总数', |
|
||||||
} |
|
||||||
|
|
||||||
var tbody_text = ''; |
|
||||||
for (k in rdata){ |
|
||||||
var desc = k; |
|
||||||
if (k in kv){ |
|
||||||
desc = kv[k]; |
|
||||||
} |
|
||||||
|
|
||||||
if (k == 'master_replid'){ |
|
||||||
tbody_text += '<tr><th>'+k+'</th><td class="overflow_hide" style="width:155px;display: inline-block;border: none;">' + rdata[k] + '</td><td>'+desc+'</td></tr>'; |
|
||||||
} else{ |
|
||||||
tbody_text += '<tr><th>'+k+'</th><td>' + rdata[k] + '</td><td>'+desc+'</td></tr>'; |
|
||||||
}
|
|
||||||
} |
|
||||||
|
|
||||||
if (tbody_text == ''){ |
|
||||||
tbody_text += '<tr><td colspan="3" style="text-align:center;">无数据/未设置集群</td></tr>'; |
|
||||||
} |
|
||||||
|
|
||||||
var con = '<div class="divtable">\ |
|
||||||
<table class="table table-hover table-bordered" style="width: 490px;">\ |
|
||||||
<thead><th style="width:80px;">字段</th><th style="width:90px;">当前值</th><th>说明</th></thead>\ |
|
||||||
<tbody>'+tbody_text+'<tbody>\ |
|
||||||
</table></div>'; |
|
||||||
$(".soft-man-con").html(con); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
function clusterNodes(version){ |
|
||||||
redisPost('cluster_nodes', version, {},function(data){ |
|
||||||
var rdata = $.parseJSON(data.data); |
|
||||||
|
|
||||||
if ('status' in rdata && !rdata.status){ |
|
||||||
layer.msg(rdata.msg,{icon:0,time:2000,shade: [0.3, '#000']}); |
|
||||||
return; |
|
||||||
} |
|
||||||
|
|
||||||
// console.log(rdata);
|
|
||||||
var tbody_text = ''; |
|
||||||
for (k in rdata){ |
|
||||||
tbody_text += '<tr><td>'+ rdata[k] +'</td></tr>'; |
|
||||||
} |
|
||||||
|
|
||||||
if (tbody_text == ''){ |
|
||||||
tbody_text += '<tr><td style="text-align:center;">无数据/未设置集群</td></tr>'; |
|
||||||
} |
|
||||||
|
|
||||||
var con = '<div class="divtable">\ |
|
||||||
<table class="table table-hover table-bordered" style="width: 490px;">\ |
|
||||||
<thead><th style="width:80px;text-align:center;">节点信息</th></thead>\ |
|
||||||
<tbody>'+tbody_text+'<tbody>\ |
|
||||||
</table></div>'; |
|
||||||
$(".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 = '<input style="width: ' + w + 'px;" class="bt-input-text mr5" name="' + rdata[i].name + '" value="' + rdata[i].value + '" type="text" >'; |
|
||||||
switch (rdata[i].type) { |
|
||||||
case 0: |
|
||||||
var selected_1 = (rdata[i].value == 1) ? 'selected' : ''; |
|
||||||
var selected_0 = (rdata[i].value == 0) ? 'selected' : ''; |
|
||||||
ibody = '<select class="bt-input-text mr5" name="' + rdata[i].name + '" style="width: ' + w + 'px;"><option value="1" ' + selected_1 + '>开启</option><option value="0" ' + selected_0 + '>关闭</option></select>' |
|
||||||
break; |
|
||||||
case 1: |
|
||||||
var selected_1 = (rdata[i].value == 'On') ? 'selected' : ''; |
|
||||||
var selected_0 = (rdata[i].value == 'Off') ? 'selected' : ''; |
|
||||||
ibody = '<select class="bt-input-text mr5" name="' + rdata[i].name + '" style="width: ' + w + 'px;"><option value="On" ' + selected_1 + '>开启</option><option value="Off" ' + selected_0 + '>关闭</option></select>' |
|
||||||
break; |
|
||||||
} |
|
||||||
mlist += '<p><span>' + rdata[i].name + '</span>' + ibody + ', <font>' + rdata[i].ps + '</font></p>' |
|
||||||
} |
|
||||||
var con = '<style>.conf_p p{margin-bottom: 2px}</style><div class="conf_p" style="margin-bottom:0">' + mlist + '\ |
|
||||||
<div style="margin-top:10px; padding-right:15px" class="text-right"><button class="btn btn-success btn-sm mr5" onclick="getRedisConfig(\'' + version + '\')">刷新</button>\ |
|
||||||
<button class="btn btn-success btn-sm" onclick="submitConf(\'' + version + '\')">保存</button></div>\ |
|
||||||
</div>' |
|
||||||
$(".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 }); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
function tidbReadme(){ |
|
||||||
var cmd_01 = '/www/server/redis/bin/redis-cli --cluster create 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 --cluster-replicas 0'; |
|
||||||
var cmd_02 = '/www/server/redis/bin/redis-cli --cluster create 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384 --cluster-replicas 1'; |
|
||||||
|
|
||||||
|
|
||||||
var readme = '<ul class="help-info-text c7">'; |
|
||||||
readme += '<li>集群创建1</li>'; |
|
||||||
readme += '<li>'+cmd_01+'</li>'; |
|
||||||
readme += '<li>集群创建2</li>'; |
|
||||||
readme += '<li>'+cmd_02+'</li>'; |
|
||||||
readme += '</ul>'; |
|
||||||
|
|
||||||
$('.soft-man-con').html(readme);
|
|
||||||
} |
|
||||||
|
|
Loading…
Reference in new issue