Skip to content
effect-analysis.component.ts 15.8 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, OnInit} from '@angular/core';
import {BusinessService} from '../business.service';
wangqinghua's avatar
wangqinghua committed
import {OverAllService} from '../../overAll/overAll.service';
import {DatePipe} from '@angular/common';
import {color} from '../../app.constants';
wangqinghua's avatar
wangqinghua committed
import {NzMessageService} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed
import {CommonService} from '../../shared/common/common.service';
wangqinghua's avatar
wangqinghua committed

@Component({
wangqinghua's avatar
wangqinghua committed
    selector: 'smart-effect-analysis',
    templateUrl: './effect-analysis.component.html',
    styles: [
wangqinghua's avatar
wangqinghua committed
            `
wangqinghua's avatar
wangqinghua committed
            .chart-div {
                border: 1px solid #dadada;
                margin-top: 20px;
                padding: 10px;
            }

            .chart-left {
                margin-left: 20px;
            }

            .chart-left p {
                margin-left: 20px;
            }
wangqinghua's avatar
wangqinghua committed

            .header > div {
wangqinghua's avatar
wangqinghua committed
                height: 250px;
                position: relative;
            }
wangqinghua's avatar
wangqinghua committed

            .header div > .position-center {
wangqinghua's avatar
wangqinghua committed
                position: absolute;
                width: 100%;
                top: 50%;
                left: 50%;
wangqinghua's avatar
wangqinghua committed
                transform: translate(-50%, -50%);
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed

            .p1 {
wangqinghua's avatar
wangqinghua committed
                font-size: 20px;
            }
wangqinghua's avatar
wangqinghua committed

            .p2 {
wangqinghua's avatar
wangqinghua committed
                font-size: 40px;
            }
wangqinghua's avatar
wangqinghua committed

            .spanBorder span.select {
wangqinghua's avatar
wangqinghua committed
                border: 1px solid #6097b7;
                color: #6097b7;
            }
wangqinghua's avatar
wangqinghua committed
        `
    ]
wangqinghua's avatar
wangqinghua committed
})
export class EffectAnalysisComponent implements OnInit {
wangqinghua's avatar
wangqinghua committed
    color = color;
    colorArr = ['#f36969', '#02c8cf', '#eaaa00', '#61a600', '#4484d4'];
wangqinghua's avatar
wangqinghua committed
    timeType = '4';
wangqinghua's avatar
wangqinghua committed
    rootList;  //业务列表
wangqinghua's avatar
wangqinghua committed
    webList;  //网站检测列表
wangqinghua's avatar
wangqinghua committed
    triggerList;   //监测点列表
    isLoading = false;
    serviceId;
    analyObj;  //业务信息
wangqinghua's avatar
wangqinghua committed
    httptestid;  //网站监测id
wangqinghua's avatar
wangqinghua committed
    analyOption;   //监测点echart
wangqinghua's avatar
wangqinghua committed

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

    //图表
    isSpinning = false;
wangqinghua's avatar
wangqinghua committed
    noData = true;
wangqinghua's avatar
wangqinghua committed
    userData = true;
wangqinghua's avatar
wangqinghua committed
    speed;
    time;
    chartSpeed;
    chartTime;
wangqinghua's avatar
wangqinghua committed
    chartUser;
wangqinghua's avatar
wangqinghua committed

    constructor(private busineSer: BusinessService, private overAllSer: OverAllService,
wangqinghua's avatar
wangqinghua committed
                private commonSer:CommonService,
wangqinghua's avatar
wangqinghua committed
                private datePipe: DatePipe, private message: NzMessageService) {
wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
wangqinghua's avatar
wangqinghua committed
        this.getServiceList();
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //更改业务
wangqinghua's avatar
wangqinghua committed
    changeService() {
        this.isLoading = true;
        this.getTriggerlist();
        this.getInfo();
wangqinghua's avatar
wangqinghua committed
        this.getWeblist();
    }

    //系统可用性, 监测点, 用户统计
    getInfo() {
        this.busineSer.serviceAnalysisCount(this.serviceId).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.analyObj = res.data;
wangqinghua's avatar
wangqinghua committed
                    this.setAnalyOption();
wangqinghua's avatar
wangqinghua committed
                }
                this.isLoading = false;
            }
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    setAnalyOption() {
        let echartData = [{
            value: this.analyObj.danger,
            name: '严重'
        }, {
            value: this.analyObj.alarm,
            name: '告警'
        }, {
            value: this.analyObj.normal,
            name: '正常'
        }, {
            value: this.analyObj.unknown,
            name: '未知'
        }];
        let rich = {
            red: {
                color: this.color.red,
                padding: [5, 4],
                align: 'center'
            },
            yellow: {
                color: this.color.yellow,
                align: 'center'
            },
            green: {
                color: this.color.green,
                align: 'center',
                padding: [21, 0]
            },
            gray: {
                color: this.color.gray,
                align: 'center'
            },
            black: {
                color: this.color.black,
                padding: [5, 4],
                align: 'center'
            },
        };
        this.analyOption = {
            title: {
                text: '监测点',
                left: 'center',
                top: '45%',
                textStyle: {
                    fontSiz: 6,
                    align: 'center'
                }
            },
            legend: {
                selectedMode: false,
                formatter: (name) => {
                    let total = this.analyObj.total;
                    return '{black|' + total + '个}';
                },
                data: [echartData[0].name],
                left: 'center',
                top: '35%',
                icon: 'none',
                align: 'center',
                textStyle: {
                    color: '#fff',
                    rich: rich
                },
            },
            series: [{
                name: '监测点',
                type: 'pie',
                radius: ['42%', '60%'],
                hoverAnimation: false,
                color: [this.color.red, this.color.yellow, this.color.green, this.color.gray],
                label: {
                    normal: {
                        formatter: (params, ticket, callback) => {
                            let total = 0; //总数量
                            let percent; //占比
                            echartData.forEach((value, index, array) => {
                                total += value.value;
                            });
wangqinghua's avatar
wangqinghua committed
                            if (params.value == 0) {
                                percent = 0;
                            } else if (params.value > 0) {
                                percent = ((params.value / total) * 100).toFixed(1);
                            }
wangqinghua's avatar
wangqinghua committed
                            return '{black|' + params.name + ':}{black|' + params.value + '个}\n{black|' + percent + '%}';
                        },
                        rich: rich
                    },
                },
                data: echartData
            }]
        };
    }

wangqinghua's avatar
wangqinghua committed
    //业务列表
    getServiceList() {
        this.busineSer.findRoot().subscribe(
            (res) => {
                this.rootList = res.data;
wangqinghua's avatar
wangqinghua committed
                if (this.rootList.length > 0) {
wangqinghua's avatar
wangqinghua committed
                    this.serviceId = this.rootList[0].serviceid;
                    this.changeService();
                }
wangqinghua's avatar
wangqinghua committed
            }
        );
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //监测点列表
    getTriggerlist() {
        this.busineSer.triggerList(this.serviceId).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    this.triggerList = res.data;
                }
            }
        );
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    //网站监测列表
    getWeblist() {
        this.busineSer.findHttptest(this.serviceId).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.webList = res.data;
wangqinghua's avatar
wangqinghua committed
                    if (this.webList.length > 0) {
wangqinghua's avatar
wangqinghua committed
                        this.selectHttp(this.webList[0]);
                    }
                    this.noData = false;
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.noData = true;
wangqinghua's avatar
wangqinghua committed
    //用户数量趋势
wangqinghua's avatar
wangqinghua committed
    userCount() {
wangqinghua's avatar
wangqinghua committed
        const data = {
wangqinghua's avatar
wangqinghua committed
            startTime: this.obj.startTime,
            endTime: this.obj.endTime,
            serviceId: this.serviceId
        };
wangqinghua's avatar
wangqinghua committed
        this.busineSer.userCount(data).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
wangqinghua's avatar
wangqinghua committed
                const response = res.data;
wangqinghua's avatar
wangqinghua committed
                if (response.length > 0) {
wangqinghua's avatar
wangqinghua committed
                    this.chartUser = {
                        legend: {
                            right: 20,
wangqinghua's avatar
wangqinghua committed
                            data: ['在线用户数', '重要用户数']
wangqinghua's avatar
wangqinghua committed
                        },
                        xAxis: {
                            type: 'category',
wangqinghua's avatar
wangqinghua committed
                            data: response.map(e => {
wangqinghua's avatar
wangqinghua committed
                                return e.createTime;
                            }),
                            boundaryGap: false,
                            axisTick: {
                                show: false
                            },
                        },
                        yAxis: {
wangqinghua's avatar
wangqinghua committed
                            name: '人数',
wangqinghua's avatar
wangqinghua committed
                            type: 'value',
                            axisTick: {
                                show: false
                            },
                        },
                        series: [
                            {
                                name: '在线用户数',
                                type: 'line',
                                smooth: true,
                                symbolSize: 6,
wangqinghua's avatar
wangqinghua committed
                                data: response.map(e => {
wangqinghua's avatar
wangqinghua committed
                                    return e.onlineUser;
                                }),
                                itemStyle: {
                                    normal: {
                                        color: '#55cece'
                                    }
                                },
                                lineStyle: {
                                    normal: {
                                        width: 3
                                    }
                                }
                            },
                            {
                                name: '重要用户数',
                                type: 'line',
                                smooth: true,
                                symbolSize: 6,
wangqinghua's avatar
wangqinghua committed
                                data: response.map(e => {
wangqinghua's avatar
wangqinghua committed
                                    return e.onlineImportantUser;
                                }),
                                itemStyle: {
                                    normal: {
                                        color: '#b7a4dc'
                                    }
                                },
                                lineStyle: {
                                    normal: {
                                        width: 3
                                    }
                                }
                            }]
                    };
                    this.userData = true;
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.userData = false;
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

wangqinghua's avatar
wangqinghua committed
    //选择网站监测
wangqinghua's avatar
wangqinghua committed
    selectHttp(item) {
wangqinghua's avatar
wangqinghua committed
        this.httptestid = item.httptestid;
        this.changeType();
    }

    //时间改变
    changeType() {
        this.isSpinning = true;
wangqinghua's avatar
wangqinghua committed
        if(this.timeType =='99') return ;
        this.obj.startTime = this.commonSer.getTimeByType(this.timeType).startTime;
        this.obj.endTime = this.commonSer.getTimeByType(this.timeType).endTime;
wangqinghua's avatar
wangqinghua committed
        this.findChart();
wangqinghua's avatar
wangqinghua committed
        this.userCount();
wangqinghua's avatar
wangqinghua committed
    }

    //监测图表
    findChart() {
        const data = {
            startTime: this.obj.startTime,
            endTime: this.obj.endTime,
            limit: '',
            httptestid: this.httptestid
        };
        this.overAllSer.findChart(data).subscribe(
            (res) => {
                if (res.errCode == 10000) {
                    const speed = res.data.speed;
                    this.speed = res.data.speed;
                    const time = res.data.time;
                    this.time = res.data.time;
                    this.setOption(speed, time);
wangqinghua's avatar
wangqinghua committed
                }
            }
        );
    }
wangqinghua's avatar
wangqinghua committed

    //绘制图表
    setOption(speed, time) {
        this.chartSpeed = {
            title: {
                text: '速度',
                left: '40%',
            },
            tooltip: {
                formatter: (params) => {
                    if (params.data) {
                        let res = params.seriesName;
                        res += '<br/>时间:' + params.name;
                        let Gbps = 1000 * 1000 * 1000;
                        let Mbps = 1000 * 1000;
                        let kbps = 1000;
                        let size = Math.abs(params.data);
                        if (size / Gbps > 1) {
                            res += '<br/>流量:' + (size / Gbps).toFixed(2) + 'Gbps';
                        } else if (size / Mbps > 1) {
                            res += '<br/>流量:' + (size / Mbps).toFixed(2) + 'Mbps';
                        } else if (size / kbps > 1) {
                            res += '<br/>流量:' + (size / kbps).toFixed(2) + 'kbps';
                        } else {
                            res += '<br/>流量:' + (size) + 'bps';
                        }
                        return res;
                    }
                }
            },
            grid: {
                left: '3%',
                right: '4%',
                bottom: '3%',
                containLabel: true
            },
            toolbox: {
                feature: {
                    saveAsImage: {
                        show: false
                    }
                }
            },
            xAxis: {
                type: 'category',
                boundaryGap: false,
                data: speed[0].data.map(res => {
                    return res.date;
                }),
            },
            yAxis: {
                type: 'value',
                axisLabel: {   //Y轴数据
wangqinghua's avatar
wangqinghua committed
                    formatter: (value) => {
wangqinghua's avatar
wangqinghua committed
                        return Math.abs(value) / 1000 + ' kbps';
                    },
                    textStyle: {
                        color: '#666'
                    }
                },
            },
            series: speed.map((res1, index) => {
                const number = res1.data.map(res2 => {
                    return res2.val;
                });
                const obj = {
                    name: res1.name,
                    type: 'line',
                    stack: '总量',
                    itemStyle: {
                        normal: {
                            lineStyle: {
                                color: this.colorArr[index]
                            }
                        }
                    },
                    data: number
                };
                return obj;
            })
        };

        this.chartTime = {
            title: {
                text: '响应时间',
                left: '40%',
            },
            tooltip: {
                // trigger: 'axis',
                formatter: (params) => {
                    if (params.data) {
                        let res = params.seriesName;
                        res += '<br/>时间:' + params.name;
wangqinghua's avatar
wangqinghua committed
                        res += '<br/>相应时间:' + params.data + 's';
wangqinghua's avatar
wangqinghua committed
                        return res;
                    }
                }
            },
            grid: {
                left: '3%',
                right: '4%',
                bottom: '3%',
                containLabel: true
            },
            toolbox: {
                feature: {
                    saveAsImage: {
                        show: false
                    }
                }
            },
            xAxis: {
                type: 'category',
                boundaryGap: false,
                data: time[0].data.map(res => {
                    return res.date;
                })
            },
            yAxis: {
                type: 'value',
                axisLabel: {   //Y轴数据
wangqinghua's avatar
wangqinghua committed
                    formatter: (value) => {
wangqinghua's avatar
wangqinghua committed
                        return value + ' s';
                    },
                    textStyle: {
                        color: '#666'
                    }
                },
            },
            series: time.map((res1, index) => {
                const number = res1.data.map(res2 => {
                    return res2.val;
                });
                const obj = {
                    name: res1.name,
                    type: 'line',
                    stack: '总量',
                    itemStyle: {
                        normal: {
                            lineStyle: {
                                color: this.colorArr[index]
                            }
                        }
                    },
                    data: number
                };
                return obj;
            })
        };

        this.isSpinning = false;
    }
wangqinghua's avatar
wangqinghua committed
}