Skip to content
server.component.ts 8.28 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, OnInit} from '@angular/core';
import {CommonService} from '../../../shared/common/common.service';
import {ActivatedRoute} from '@angular/router';
import {NzMessageService} from 'ng-zorro-antd';
import {OverAllService} from '../../overAll.service';
import {HostComponent} from '../../host.component';
import {HostFlow} from '../../../app.constants';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-server',
    templateUrl: './server.component.html',
    styles: []
wangqinghua's avatar
wangqinghua committed
})
export class ServerComponent implements OnInit {

wangqinghua's avatar
wangqinghua committed
    hostId;  //主机ID
    equipmentType;  //主机类型
    server;
wangqinghua's avatar
wangqinghua committed
    noData = false;
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    targetFlow = HostFlow;   //主机指标
    timeList = [
        {'label': '最近一小时', value: '0'},
        {'label': '最近一天', value: '2'},
        {'label': '最近三天', value: '3'},
        {'label': '最近一周', value: '4'},
    ];
wangqinghua's avatar
wangqinghua committed
    timeTypeTrend = '0';
    timeTypeHistory = '0';
wangqinghua's avatar
wangqinghua committed

    isTrendLoading = false;
    chartTrendOption;

    isHistoryLoading = false;
    chartHistoryOption;

    trendObj = {   //指标趋势
        type: 'total_flow',
        startTime: '',
        endTime: ''
    };

    historyObj = {
        startTime: '',
        endTime: ''
    };

    hostObj = {
wangqinghua's avatar
wangqinghua committed
        disk: [],
wangqinghua's avatar
wangqinghua committed
        used: null,
        cpu: null,
        losed: null,
wangqinghua's avatar
wangqinghua committed
        response: null
wangqinghua's avatar
wangqinghua committed
    };

wangqinghua's avatar
wangqinghua committed
    isDiskLoading = false;
    chartDiskOption;
    diskType;

wangqinghua's avatar
wangqinghua committed
    constructor(private commonSer: CommonService, private routerInfo: ActivatedRoute,
                private message: NzMessageService, private overAllSer: OverAllService,
                private hostCom: HostComponent) {
        this.routerInfo.queryParams.subscribe(queryParams => {
            this.hostId = queryParams.hostId;
            this.equipmentType = queryParams.equipmentType;
        });
    }

    ngOnInit() {
        this.getDetail();
wangqinghua's avatar
wangqinghua committed
        this.changeHistory('0');
        this.changeTrend('0');
        this.getDisk();
wangqinghua's avatar
wangqinghua committed
    }

    getDetail() {
        const data = {
            hostId: this.hostId,
        };
        this.overAllSer.findDetailed(this.hostId).subscribe(
            (res) => {
wangqinghua's avatar
wangqinghua committed
                if(res.errCode == 10000){
                    this.server = res.data[0];
                }else{
                    this.message.error(res.errMsg);
                }
wangqinghua's avatar
wangqinghua committed
            }
        );
        //内存使用率
        this.overAllSer.used(data).subscribe(
            (res) => {
                if (res.data) {
wangqinghua's avatar
wangqinghua committed
                    this.hostObj.used = res.data.used;
wangqinghua's avatar
wangqinghua committed
                } else {
                    this.hostObj.used = 0;
                }
            }
        );
        //cpu使用率
        this.overAllSer.cupUsed(data).subscribe(
            (res) => {
                if (res.data) {
wangqinghua's avatar
wangqinghua committed
                    this.hostObj.cpu = res.data.cpuUsed;
wangqinghua's avatar
wangqinghua committed
                } else {
                    this.hostObj.cpu = 0;
                }
            }
        );
        //丢包率
        this.overAllSer.losed(this.hostId).subscribe(
            (res) => {
                if (res.data) {
                    this.hostObj.losed = res.data.losed;
                } else {
                    this.hostObj.losed = 0;
                }
            }
        );
wangqinghua's avatar
wangqinghua committed
        //响应时间
        this.overAllSer.responseTime(this.hostId).subscribe(
            (res) => {
                if (res.data) {
wangqinghua's avatar
wangqinghua committed
                    this.hostObj.response = res.data.responseTime;
wangqinghua's avatar
wangqinghua committed
                } else {
                    this.hostObj.response = 0;
                }
            }
        );
    }

    // 分区
    getDisk() {
        const data = {
            hostId: this.hostId,
        };
        this.isDiskLoading = true;
        //磁盘使用率
        this.overAllSer.disks(data).subscribe(
            (res) => {
                this.hostObj.disk = res.data.disks;
                if (this.hostObj.disk.length > 0) {
wangqinghua's avatar
wangqinghua committed
                    this.diskType = 0;
wangqinghua's avatar
wangqinghua committed
                    this.setDiskChart(0);
wangqinghua's avatar
wangqinghua committed
                    this.noData = false;
                }else {
                    this.noData = true;
wangqinghua's avatar
wangqinghua committed
                }
            }
        );
    }

    setDiskChart(index) {
        const data = this.hostObj.disk[index];
        this.chartDiskOption = {
            tooltip: {
                trigger: 'item',
                formatter: '{a} <br/>{b}: {c} ({d}%)'
            },
            series: [
                {
                    type: 'pie',
                    radius: ['50%', '70%'],
                    avoidLabelOverlap: false,
                    label: {
                        normal: {
                            show: false,
                            position: 'center'
                        },
                        emphasis: {
                            show: true,
                            textStyle: {
                                fontSize: '30',
                                fontWeight: 'bold'
                            }
                        }
                    },
                    labelLine: {
                        normal: {
wangqinghua's avatar
wangqinghua committed
                            show: true
wangqinghua's avatar
wangqinghua committed
                        }
                    },
                    data: [
                        {value: data.used, name: '已使用'},
                        {value: data.total - data.used, name: '未使用'},
                    ]
                }
            ]
        };
wangqinghua's avatar
wangqinghua committed
        this.isDiskLoading = false;
wangqinghua's avatar
wangqinghua committed
    }

    //获取趋势数据
    getTrend() {
        const data = {
            type: this.trendObj.type,
            hostid: this.hostId,
            startTime: this.trendObj.startTime,
            endTime: this.trendObj.endTime
        };
        this.overAllSer.findChartByKey(data).subscribe(
            (res) => {
                this.setTrendChart(res.data);
            }
        );
    }

    //设置指标趋势
    setTrendChart(data) {
        this.chartTrendOption = {
            xAxis: {
                type: 'category',
                axisLine: {
                    lineStyle: {
                        color: '#b6d0f0',
                    }
                },
                data: data.map(e => {
                    return e.time;
                })
            },
            yAxis: {
                axisLine: {
                    lineStyle: {
                        color: '#b6d0f0',
                    }
                },
                type: 'value'
            },
wangqinghua's avatar
wangqinghua committed
            series: [
                {
                    data: data.map(e => {
                        return e.val;
                    }),
                    type: 'line',
                    name: '',
                }
            ]
wangqinghua's avatar
wangqinghua committed
        };
        this.isTrendLoading = false;
    }

    //获取历史趋势
    getHistory() {
wangqinghua's avatar
wangqinghua committed
        const data = {
            type: 'icmpping',
            hostid: this.hostId,
            startTime: this.historyObj.startTime,
            endTime: this.historyObj.endTime
        };
        this.overAllSer.findChartByKey(data).subscribe(
            (res) => {
                this.setHistoryChart(res.data);
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

    //设置指标趋势
    setHistoryChart(data) {
        this.chartHistoryOption = {
            xAxis: {
                type: 'category',
                axisLine: {
                    lineStyle: {
                        color: '#b6d0f0',
                    }
                },
                data: data.map(e => {
                    return e.time;
                })
            },
            yAxis: {
                axisLine: {
                    lineStyle: {
                        color: '#b6d0f0',
                    }
                },
                type: 'value'
            },
wangqinghua's avatar
wangqinghua committed
            series: [
                {
                    data: data.map(e => {
                        return e.val;
                    }),
                    type: 'line'
                }
            ]
wangqinghua's avatar
wangqinghua committed
        };
        this.isHistoryLoading = false;
    }

wangqinghua's avatar
wangqinghua committed
    changeTrend(e) {
wangqinghua's avatar
wangqinghua committed
        this.isTrendLoading = true;
        const timeObj = this.commonSer.getTimeByType(e);
        this.trendObj.startTime = timeObj.startTime;
        this.trendObj.endTime = timeObj.endTime;
        this.getTrend();
    }

wangqinghua's avatar
wangqinghua committed
    changeHistory(e) {
wangqinghua's avatar
wangqinghua committed
        this.isHistoryLoading = true;
        const timeObj = this.commonSer.getTimeByType(e);
        this.historyObj.startTime = timeObj.startTime;
        this.historyObj.endTime = timeObj.endTime;
        this.getHistory();
    }
wangqinghua's avatar
wangqinghua committed

}