From 458670ed298ed05086bdb6436744a849f443c1af Mon Sep 17 00:00:00 2001 From: Rivery <9858560+xigongdaEricyang@users.noreply.github.com> Date: Thu, 25 May 2023 17:43:11 +0800 Subject: [PATCH] feat: update monitor dashboard (#263) --- src/components/Charts/SpaceChart.less | 11 ++++++++--- src/components/DashboardCard/index.less | 2 +- src/components/MetricCard/index.tsx | 14 +++----------- src/pages/MachineDashboard/Cards/DiskCard.tsx | 4 ++-- .../ServiceDashboard/ServiceOverview/index.tsx | 4 ++-- src/utils/interface.ts | 9 +++++++++ src/utils/promQL.ts | 2 +- 7 files changed, 26 insertions(+), 20 deletions(-) diff --git a/src/components/Charts/SpaceChart.less b/src/components/Charts/SpaceChart.less index a345ad4d..89685dc3 100644 --- a/src/components/Charts/SpaceChart.less +++ b/src/components/Charts/SpaceChart.less @@ -82,6 +82,10 @@ .disk-info-content { display: flex; + position: sticky; + top: 0; + background: #fff; + z-index: 10; } .disk-th { @@ -112,7 +116,7 @@ justify-content: center; } -.disk-tr-item > div:not(:last-child) { +.disk-tr-item>div:not(:last-child) { margin-bottom: 20px; } @@ -201,9 +205,10 @@ position: absolute !important; top: 10px; right: 70px; + // width: 200px; - > .ant-select-arrow { + >.ant-select-arrow { margin-top: -8px !important; color: #000 !important; } -} +} \ No newline at end of file diff --git a/src/components/DashboardCard/index.less b/src/components/DashboardCard/index.less index d8e4c72e..c1018115 100644 --- a/src/components/DashboardCard/index.less +++ b/src/components/DashboardCard/index.less @@ -1,6 +1,6 @@ .dashboard-card { padding: 5px; - min-height: 293px; + // min-height: 293px; height: 320px; > .inner { diff --git a/src/components/MetricCard/index.tsx b/src/components/MetricCard/index.tsx index f8c3c3bc..d5b8e548 100644 --- a/src/components/MetricCard/index.tsx +++ b/src/components/MetricCard/index.tsx @@ -3,20 +3,11 @@ import intl from 'react-intl-universal'; import LineCard from '@/components/DashboardCard/LineCard'; import { VALUE_TYPE } from '@/utils/promQL'; -import { ILineChartMetric } from '@/utils/interface'; +import { ILineChartMetric, PromResultMetric } from '@/utils/interface'; import { asyncBatchQueries } from '@/requests'; import { calcTimeRange, TIME_OPTION_TYPE } from '@/utils/dashboard'; import { getQueryRangeInfo } from '@/utils'; -export interface PromResultMetric { - componentType: string; - instance: string; - instanceName: string; - nebula_cluster: string; - __name__: string; - device?: string; -} - interface IProps { valueType: VALUE_TYPE; queries: any; @@ -43,6 +34,7 @@ const MetricCard = forwardRef((props: IProps, ref) => { } const asyncGetMetricData = async (queries) => { + if (queries.length === 0) return; const curTimeRange = calcTimeRange(timeRange); const { start, end, step } = getQueryRangeInfo(curTimeRange[0], curTimeRange[1]); const data: any = await asyncBatchQueries(queries.map(q => ({ @@ -75,7 +67,7 @@ const MetricCard = forwardRef((props: IProps, ref) => { {chartRef.current = ref;}} + onRef={(ref) => { chartRef.current = ref; }} valueType={valueType} loading={false} /> diff --git a/src/pages/MachineDashboard/Cards/DiskCard.tsx b/src/pages/MachineDashboard/Cards/DiskCard.tsx index 6238f9f6..3ab3171d 100644 --- a/src/pages/MachineDashboard/Cards/DiskCard.tsx +++ b/src/pages/MachineDashboard/Cards/DiskCard.tsx @@ -34,11 +34,11 @@ const DiskCard = forwardRef((props: IProps, ref) => { const queries: any = [ { refId: 'diskSize', - query: `node_filesystem_size_bytes{fstype=~"ext.*|xfs",mountpoint !~".*pod.*"${clusterSuffix1}${instanceSuffix}}` + query: `node_filesystem_size_bytes{mountpoint !~".*pod.*"${clusterSuffix1}${instanceSuffix}}` }, { refId: 'diskUsed', - query: `node_filesystem_size_bytes{fstype=~"ext.*|xfs",mountpoint !~".*pod.*"${clusterSuffix1}${instanceSuffix}} - node_filesystem_free_bytes{fstype=~"ext.*|xfs",mountpoint !~".*pod.*"${clusterSuffix1}${instanceSuffix}}` + query: `node_filesystem_size_bytes{mountpoint !~".*pod.*"${clusterSuffix1}${instanceSuffix}} - node_filesystem_free_bytes{fstype=~"ext.*|xfs",mountpoint !~".*pod.*"${clusterSuffix1}${instanceSuffix}}` } ]; const data = await asyncBatchQueries(queries); diff --git a/src/pages/ServiceDashboard/ServiceOverview/index.tsx b/src/pages/ServiceDashboard/ServiceOverview/index.tsx index 63d54b00..8b6b210f 100644 --- a/src/pages/ServiceDashboard/ServiceOverview/index.tsx +++ b/src/pages/ServiceDashboard/ServiceOverview/index.tsx @@ -2,12 +2,12 @@ import React, { useEffect, useMemo, useRef, useState } from 'react'; import intl from 'react-intl-universal'; import { connect } from 'react-redux'; -import { BatchQueryItem, IServiceMetricItem, ServiceName } from '@/utils/interface'; +import { BatchQueryItem, IServiceMetricItem, PromResultMetric, ServiceName } from '@/utils/interface'; import ServiceHeader from '@/components/Service/ServiceHeader'; import Icon from '@/components/Icon'; import { AggregationType, TIME_OPTION_TYPE } from '@/utils/dashboard'; import { ServicePanelConfig } from '../defaultPanelConfig'; -import MetricCard, { PromResultMetric } from '@/components/MetricCard'; +import MetricCard from '@/components/MetricCard'; import styles from './index.module.less'; import { getClusterPrefix } from '@/utils/promQL'; diff --git a/src/utils/interface.ts b/src/utils/interface.ts index 919f9035..837a7906 100644 --- a/src/utils/interface.ts +++ b/src/utils/interface.ts @@ -186,4 +186,13 @@ export interface MachinePanelConfig { valueType: VALUE_TYPE; showIndex?: number; refIds: string[]; +} + +export interface PromResultMetric { + componentType: string; + instance: string; + instanceName: string; + nebula_cluster: string; + __name__: string; + device?: string; } \ No newline at end of file diff --git a/src/utils/promQL.ts b/src/utils/promQL.ts index 2161571b..1bfd3dde 100644 --- a/src/utils/promQL.ts +++ b/src/utils/promQL.ts @@ -152,7 +152,7 @@ export const getClusterPrefix = () => { return 'nebula_cluster'; } -export const diskPararms = 'fstype=~"ext.*|xfs",mountpoint !~".*pod.*"'; +export const diskPararms = 'mountpoint !~".*pod.*"'; const getPromqlLabel = (cluster?, device?: string, instance?: string) => { const clusterSuffix = cluster ? `${getClusterPrefix()} = "${cluster}"` : '';