Skip to content

Commit

Permalink
sql, ui: introduce sql.crud_query.count QPS metric
Browse files Browse the repository at this point in the history
Previously, customers struggled to get an accurate picture of "QPS" on
a cluster, due to a number of factors.

First, our `sql.query.count` metric includes counts of transaction
control statements which greatly inflate the "QPS" in a confusing way
to a customer.

Second, the Metrics page in DB Console included a "QPS" metric which
was a client-side sum of the insert/update/delete/select counters.
This metric wasn't available to scrape or view in line graphs which
led to confusion.

In this PR we introduce the `sql.crud_query.count` and
`sql.crud_query.started.count` metric which is incremented along with
the insert/update/delete/select counters.

This metric is added to the SQL chart at the top of the overview
dashboard. That chart is renamed to have the title `SQL Queries Per
Second` for clarity and the box on the right hand side now uses this
metric directly.

Resolves: CRDB-25876
Epic: CRDB-37557

Release note (ops change): Two new metrics are available
`sql.crud_query.count` and `sql.crud_query.started.count` which
measure the number of insert/update/delete/select queries executed and
started respectively.

Release note (ui change): The headline SQL Statements graph on the
Overview and SQL dashboard pages in DB Console now show "Total
Queries" as a general QPS metric.
  • Loading branch information
dhartunian committed Oct 22, 2024
1 parent 661366d commit a032686
Show file tree
Hide file tree
Showing 6 changed files with 49 additions and 34 deletions.
12 changes: 8 additions & 4 deletions docs/generated/metrics/metrics.html
Original file line number Diff line number Diff line change
Expand Up @@ -1560,6 +1560,10 @@
<tr><td>APPLICATION</td><td>sql.copy.nonatomic.started.count.internal</td><td>Number of non-atomic COPY SQL statements started (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.copy.started.count</td><td>Number of COPY SQL statements started</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.copy.started.count.internal</td><td>Number of COPY SQL statements started (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.crud_query.count</td><td>Number of SQL SELECT, INSERT, UPDATE, DELETE statements successfully executed</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.crud_query.count.internal</td><td>Number of SQL SELECT, INSERT, UPDATE, DELETE statements successfully executed (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.crud_query.started.count</td><td>Number of SQL SELECT, INSERT, UPDATE, DELETE statements started</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.crud_query.started.count.internal</td><td>Number of SQL SELECT, INSERT, UPDATE, DELETE statements started (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.ddl.count</td><td>Number of SQL DDL statements successfully executed</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.ddl.count.internal</td><td>Number of SQL DDL statements successfully executed (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.ddl.started.count</td><td>Number of SQL DDL statements started</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
Expand Down Expand Up @@ -1675,10 +1679,10 @@
<tr><td>APPLICATION</td><td>sql.pre_serve.mem.cur</td><td>Current memory usage for SQL connections prior to routing the connection to the target SQL server</td><td>Memory</td><td>GAUGE</td><td>BYTES</td><td>AVG</td><td>NONE</td></tr>
<tr><td>APPLICATION</td><td>sql.pre_serve.mem.max</td><td>Memory usage for SQL connections prior to routing the connection to the target SQL server</td><td>Memory</td><td>HISTOGRAM</td><td>BYTES</td><td>AVG</td><td>NONE</td></tr>
<tr><td>APPLICATION</td><td>sql.pre_serve.new_conns</td><td>Number of SQL connections created prior to routing the connection to the target SQL server</td><td>Connections</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.count</td><td>Number of SQL queries executed</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.count.internal</td><td>Number of SQL queries executed (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.started.count</td><td>Number of SQL queries started</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.started.count.internal</td><td>Number of SQL queries started (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.count</td><td>Number of SQL operations started including queries, and transaction control statements</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.count.internal</td><td>Number of SQL operations started including queries, and transaction control statements (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.started.count</td><td>Number of SQL operations started including queries, and transaction control statements</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.query.started.count.internal</td><td>Number of SQL operations started including queries, and transaction control statements (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.restart_savepoint.count</td><td>Number of `SAVEPOINT cockroach_restart` statements successfully executed</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.restart_savepoint.count.internal</td><td>Number of `SAVEPOINT cockroach_restart` statements successfully executed (internal queries)</td><td>SQL Internal Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
<tr><td>APPLICATION</td><td>sql.restart_savepoint.release.count</td><td>Number of `RELEASE SAVEPOINT cockroach_restart` statements successfully executed</td><td>SQL Statements</td><td>COUNTER</td><td>COUNT</td><td>AVG</td><td>NON_NEGATIVE_DERIVATIVE</td></tr>
Expand Down
10 changes: 10 additions & 0 deletions pkg/sql/conn_executor.go
Original file line number Diff line number Diff line change
Expand Up @@ -4435,6 +4435,8 @@ type StatementCounters struct {
UpdateCount telemetry.CounterWithMetric
InsertCount telemetry.CounterWithMetric
DeleteCount telemetry.CounterWithMetric
// CRUDQueryCount includes all 4 CRUD statements above.
CRUDQueryCount telemetry.CounterWithMetric

// Transaction operations.
TxnBeginCount telemetry.CounterWithMetric
Expand Down Expand Up @@ -4499,6 +4501,8 @@ func makeStartedStatementCounters(internal bool) StatementCounters {
getMetricMeta(MetaInsertStarted, internal)),
DeleteCount: telemetry.NewCounterWithMetric(
getMetricMeta(MetaDeleteStarted, internal)),
CRUDQueryCount: telemetry.NewCounterWithMetric(
getMetricMeta(MetaCRUDStarted, internal)),
DdlCount: telemetry.NewCounterWithMetric(
getMetricMeta(MetaDdlStarted, internal)),
CopyCount: telemetry.NewCounterWithMetric(
Expand Down Expand Up @@ -4542,6 +4546,8 @@ func makeExecutedStatementCounters(internal bool) StatementCounters {
getMetricMeta(MetaInsertExecuted, internal)),
DeleteCount: telemetry.NewCounterWithMetric(
getMetricMeta(MetaDeleteExecuted, internal)),
CRUDQueryCount: telemetry.NewCounterWithMetric(
getMetricMeta(MetaCRUDExecuted, internal)),
DdlCount: telemetry.NewCounterWithMetric(
getMetricMeta(MetaDdlExecuted, internal)),
CopyCount: telemetry.NewCounterWithMetric(
Expand All @@ -4562,12 +4568,16 @@ func (sc *StatementCounters) incrementCount(ex *connExecutor, stmt tree.Statemen
sc.TxnBeginCount.Inc()
case *tree.Select:
sc.SelectCount.Inc()
sc.CRUDQueryCount.Inc()
case *tree.Update:
sc.UpdateCount.Inc()
sc.CRUDQueryCount.Inc()
case *tree.Insert:
sc.InsertCount.Inc()
sc.CRUDQueryCount.Inc()
case *tree.Delete:
sc.DeleteCount.Inc()
sc.CRUDQueryCount.Inc()
case *tree.CommitTransaction:
sc.TxnCommitCount.Inc()
case *tree.RollbackTransaction:
Expand Down
16 changes: 14 additions & 2 deletions pkg/sql/exec_util.go
Original file line number Diff line number Diff line change
Expand Up @@ -833,7 +833,7 @@ var (
// Below are the metadata for the statement started counters.
MetaQueryStarted = metric.Metadata{
Name: "sql.query.started.count",
Help: "Number of SQL queries started",
Help: "Number of SQL operations started including queries, and transaction control statements",
Measurement: "SQL Statements",
Unit: metric.Unit_COUNT,
}
Expand Down Expand Up @@ -885,6 +885,12 @@ var (
Measurement: "SQL Statements",
Unit: metric.Unit_COUNT,
}
MetaCRUDStarted = metric.Metadata{
Name: "sql.crud_query.started.count",
Help: "Number of SQL SELECT, INSERT, UPDATE, DELETE statements started",
Measurement: "SQL Statements",
Unit: metric.Unit_COUNT,
}
MetaSavepointStarted = metric.Metadata{
Name: "sql.savepoint.started.count",
Help: "Number of SQL SAVEPOINT statements started",
Expand Down Expand Up @@ -949,7 +955,7 @@ var (
// Below are the metadata for the statement executed counters.
MetaQueryExecuted = metric.Metadata{
Name: "sql.query.count",
Help: "Number of SQL queries executed",
Help: "Number of SQL operations started including queries, and transaction control statements",
Measurement: "SQL Statements",
Unit: metric.Unit_COUNT,
}
Expand Down Expand Up @@ -1001,6 +1007,12 @@ var (
Measurement: "SQL Statements",
Unit: metric.Unit_COUNT,
}
MetaCRUDExecuted = metric.Metadata{
Name: "sql.crud_query.count",
Help: "Number of SQL SELECT, INSERT, UPDATE, DELETE statements successfully executed",
Measurement: "SQL Statements",
Unit: metric.Unit_COUNT,
}
MetaSavepointExecuted = metric.Metadata{
Name: "sql.savepoint.count",
Help: "Number of SQL SAVEPOINT statements successfully executed",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,12 +30,12 @@ export default function (props: GraphDashboardProps) {

return [
<LineGraph
title="SQL Statements"
title="SQL Queries Per Second"
isKvGraph={false}
sources={nodeSources}
tenantSource={tenantSource}
tooltip={`A moving average of the number of SELECT, INSERT, UPDATE, and DELETE
statements successfully executed per second ${tooltipSelection}.`}
statements, and the sum of all four, successfully executed per second ${tooltipSelection}.`}
showMetricsInTooltip={true}
preCalcGraphSize={true}
>
Expand All @@ -60,6 +60,11 @@ export default function (props: GraphDashboardProps) {
title="Deletes"
nonNegativeRate
/>
<Metric
name="cr.node.sql.crud_query.count"
title="Total Queries"
nonNegativeRate
/>
</Axis>
</LineGraph>,

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,12 +137,12 @@ export default function (props: GraphDashboardProps) {
</LineGraph>,

<LineGraph
title="SQL Statements"
title="SQL Queries Per Second"
isKvGraph={false}
sources={nodeSources}
tenantSource={tenantSource}
tooltip={`A ten-second moving average of the # of SELECT, INSERT, UPDATE, and
DELETE statements successfully executed per second ${tooltipSelection}.`}
DELETE statements, and the sum of all four, successfully executed per second ${tooltipSelection}.`}
showMetricsInTooltip={true}
>
<Axis label="queries">
Expand All @@ -166,6 +166,11 @@ export default function (props: GraphDashboardProps) {
title="Deletes"
nonNegativeRate
/>
<Metric
name="cr.node.sql.crud_query.count"
title="Total Queries"
nonNegativeRate
/>
</Axis>
</LineGraph>,

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,19 +10,19 @@ import { useSelector } from "react-redux";
import { Link } from "react-router-dom";
import { createSelector } from "reselect";

import { Tooltip, Anchor } from "src/components";
import { Anchor, Tooltip } from "src/components";
import { nodeStatusesSelector, nodeSumsSelector } from "src/redux/nodes";
import { howAreCapacityMetricsCalculated } from "src/util/docs";
import { EventBox } from "src/views/cluster/containers/events";
import { Metric } from "src/views/shared/components/metricQuery";
import {
SummaryBar,
SummaryLabel,
SummaryMetricsAggregator,
SummaryMetricStat,
SummaryStat,
SummaryStatBreakdown,
SummaryStatMessage,
SummaryMetricsAggregator,
} from "src/views/shared/components/summaryBar";

/**
Expand Down Expand Up @@ -145,28 +145,7 @@ export default function (props: ClusterSummaryProps) {
>
<Metric
sources={props.nodeSources}
name="cr.node.sql.select.count"
title="Queries/Sec"
tenantSource={props.tenantSource}
nonNegativeRate
/>
<Metric
sources={props.nodeSources}
name="cr.node.sql.insert.count"
title="Queries/Sec"
tenantSource={props.tenantSource}
nonNegativeRate
/>
<Metric
sources={props.nodeSources}
name="cr.node.sql.update.count"
title="Queries/Sec"
tenantSource={props.tenantSource}
nonNegativeRate
/>
<Metric
sources={props.nodeSources}
name="cr.node.sql.delete.count"
name="cr.node.sql.crud_query.count"
title="Queries/Sec"
tenantSource={props.tenantSource}
nonNegativeRate
Expand Down

0 comments on commit a032686

Please sign in to comment.