|
|
@ -26,11 +26,11 @@ function ladpPost(method, version, args,callback){ |
|
|
|
},'json');
|
|
|
|
},'json');
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function redisPostCallbak(method, version, args,callback){ |
|
|
|
function ladpPostCallbak(method, version, args,callback){ |
|
|
|
var loadT = layer.msg('正在获取...', { icon: 16, time: 0, shade: 0.3 }); |
|
|
|
var loadT = layer.msg('正在获取...', { icon: 16, time: 0, shade: 0.3 }); |
|
|
|
|
|
|
|
|
|
|
|
var req_data = {}; |
|
|
|
var req_data = {}; |
|
|
|
req_data['name'] = 'redis'; |
|
|
|
req_data['name'] = 'ladp'; |
|
|
|
req_data['func'] = method; |
|
|
|
req_data['func'] = method; |
|
|
|
args['version'] = version; |
|
|
|
args['version'] = version; |
|
|
|
|
|
|
|
|
|
|
@ -53,183 +53,9 @@ function redisPostCallbak(method, version, args,callback){ |
|
|
|
},'json');
|
|
|
|
},'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) { |
|
|
|
function getRedisConfig(version) { |
|
|
|
redisPost('get_redis_conf', version,'',function(data){ |
|
|
|
ladpPost('get_redis_conf', version,'',function(data){ |
|
|
|
// console.log(data);
|
|
|
|
// console.log(data);
|
|
|
|
var rdata = $.parseJSON(data.data); |
|
|
|
var rdata = $.parseJSON(data.data); |
|
|
|
// console.log(rdata);
|
|
|
|
// console.log(rdata);
|
|
|
@ -280,16 +106,9 @@ function submitConf(version) { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function redisReadme(){ |
|
|
|
function ladpReadme(){ |
|
|
|
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">'; |
|
|
|
var readme = '<ul class="help-info-text c7">'; |
|
|
|
readme += '<li>集群创建1</li>'; |
|
|
|
readme += '<li>集群创建1</li>'; |
|
|
|
readme += '<li>'+cmd_01+'</li>'; |
|
|
|
|
|
|
|
readme += '<li>集群创建2</li>'; |
|
|
|
|
|
|
|
readme += '<li>'+cmd_02+'</li>'; |
|
|
|
|
|
|
|
readme += '</ul>'; |
|
|
|
readme += '</ul>'; |
|
|
|
|
|
|
|
|
|
|
|
$('.soft-man-con').html(readme);
|
|
|
|
$('.soft-man-con').html(readme);
|
|
|
|