Skip to content

Commit

Permalink
ui: add CPU column on Insights
Browse files Browse the repository at this point in the history
Part Of cockroachdb#87213

Adds CPU Time column on Statement and Transaction
Insights pages and their respective details pages.

Release note (ui change): Add CPU Time to Statement and
Transaction Insights.
  • Loading branch information
maryliag committed Jan 31, 2023
1 parent fd5d88b commit fff0785
Show file tree
Hide file tree
Showing 9 changed files with 50 additions and 12 deletions.
5 changes: 4 additions & 1 deletion pkg/ui/workspaces/cluster-ui/src/api/stmtInsightsApi.ts
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ export type StmtInsightsResponseRow = {
problem: string;
index_recommendations: string[];
plan_gist: string;
cpu_sql_nanos: number;
};

const stmtColumns = `
Expand Down Expand Up @@ -94,7 +95,8 @@ last_retry_reason,
causes,
problem,
index_recommendations,
plan_gist
plan_gist,
cpu_sql_nanos
`;

const stmtInsightsOverviewQuery = (filters?: StmtInsightsReq): string => {
Expand Down Expand Up @@ -206,6 +208,7 @@ export function formatStmtInsights(
InsightExecEnum.STATEMENT,
),
planGist: row.plan_gist,
cpuNanos: row.cpu_sql_nanos,
} as StmtInsightEvent;
});
}
5 changes: 4 additions & 1 deletion pkg/ui/workspaces/cluster-ui/src/api/txnInsightsApi.ts
Original file line number Diff line number Diff line change
Expand Up @@ -410,6 +410,7 @@ type TxnInsightsResponseRow = {
problems: string[];
causes: string[];
stmt_execution_ids: string[];
cpu_sql_nanos: number;
};

type TxnQueryFilters = {
Expand Down Expand Up @@ -441,7 +442,8 @@ contention,
last_retry_reason,
problems,
causes,
stmt_execution_ids`;
stmt_execution_ids,
cpu_sql_nanos`;

if (filters?.execID) {
return `
Expand Down Expand Up @@ -503,6 +505,7 @@ function formatTxnInsightsRow(row: TxnInsightsResponseRow): TxnInsightEvent {
contentionTime: moment.duration(row.contention ?? 0),
insights,
stmtExecutionIDs: row.stmt_execution_ids,
cpuNanos: row.cpu_sql_nanos,
};
}

Expand Down
21 changes: 11 additions & 10 deletions pkg/ui/workspaces/cluster-ui/src/insights/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,23 +28,24 @@ export enum InsightExecEnum {

// Common fields for both txn and stmt insights.
export type InsightEventBase = {
transactionExecutionID: string;
transactionFingerprintID: string;
application: string;
contentionTime?: moment.Duration;
cpuNanos: number;
elapsedTimeMillis: number;
endTime: Moment;
implicitTxn: boolean;
sessionID: string;
username: string;
insights: Insight[];
lastRetryReason?: string;
priority: string;
query: string;
retries: number;
application: string;
rowsRead: number;
rowsWritten: number;
sessionID: string;
startTime: Moment;
endTime: Moment;
elapsedTimeMillis: number;
query: string;
contentionTime?: moment.Duration;
insights: Insight[];
transactionExecutionID: string;
transactionFingerprintID: string;
username: string;
};

export type TxnInsightEvent = InsightEventBase & {
Expand Down
2 changes: 2 additions & 0 deletions pkg/ui/workspaces/cluster-ui/src/insights/utils.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ const statementInsightMock: StmtInsightEvent = {
insights: [failedExecutionInsight(InsightExecEnum.STATEMENT)],
indexRecommendations: [],
planGist: "gist",
cpuNanos: 50,
};

function mockStmtInsightEvent(
Expand Down Expand Up @@ -110,6 +111,7 @@ const txnInsightEventMock: TxnInsightEvent = {
endTime: moment(),
elapsedTimeMillis: 1,
stmtExecutionIDs: [statementInsightMock.statementExecutionID],
cpuNanos: 50,
};

function mockTxnInsightEvent(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,10 @@ export const StatementInsightDetailsOverviewTab: React.FC<
label="Elapsed Time"
value={Duration(insightDetails.elapsedTimeMillis * 1e6)}
/>
<SummaryCardItem
label={"CPU Time"}
value={Duration(insightDetails.cpuNanos)}
/>
<SummaryCardItem
label="Rows Read"
value={Count(insightDetails.rowsRead)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -139,6 +139,10 @@ export const TransactionInsightDetailsOverviewTab: React.FC<Props> = ({
label="Elapsed Time"
value={Duration(txnDetails.elapsedTimeMillis * 1e6)}
/>
<SummaryCardItem
label="CPU Time"
value={Duration(txnDetails.cpuNanos)}
/>
<SummaryCardItem
label="Rows Read"
value={Count(txnDetails.rowsRead)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,13 @@ export function makeStatementInsightsColumns(
item.contentionTime?.asMilliseconds() ?? -1,
showByDefault: false,
},
{
name: "cpu",
title: insightsTableTitles.cpu(execType),
cell: (item: StmtInsightEvent) => Duration(item.cpuNanos),
sort: (item: StmtInsightEvent) => item.cpuNanos,
showByDefault: false,
},
{
name: "isFullScan",
title: insightsTableTitles.isFullScan(execType),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,13 @@ export function makeTransactionInsightsColumns(
Duration((item.contentionTime?.asMilliseconds() ?? 0) * 1e6),
sort: item => item.contentionTime?.asMilliseconds() ?? 0,
},
{
name: "cpu",
title: insightsTableTitles.cpu(execType),
cell: item => Duration(item.cpuNanos),
sort: item => item.cpuNanos,
showByDefault: false,
},
{
name: "applicationName",
title: insightsTableTitles.applicationName(execType),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ export const insightsColumnLabels = {
databaseName: "Database Name",
tableName: "Table Name",
indexName: "Index Name",
cpu: "CPU Time",
};

export type InsightsTableColumnKeys = keyof typeof insightsColumnLabels;
Expand Down Expand Up @@ -206,4 +207,10 @@ export const insightsTableTitles: InsightsTableTitleType = {
"rowsProcessed",
);
},
cpu: (_: InsightExecEnum) => {
return makeToolTip(
<p>{`CPU Time spent executing within the specified time interval.`}</p>,
"cpu",
);
},
};

0 comments on commit fff0785

Please sign in to comment.