> ## Documentation Index
> Fetch the complete documentation index at: https://cosmos-docs-sync-security-docs.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# TMCore QA 37

# Tendermint Core QA Results v0.37.x

## Issues Discovered

During this iteration of the QA process, the following issues were found:

* (critical, fixed) [#9533] - This bug caused full nodes to sometimes get stuck
  when blocksyncing, requiring a manual restart to unblock them. Importantly,
  this bug was also present in v0.34.x and the fix was also backported in
  [#9534].
* (critical, fixed) [#9539] - `loadtime` is very likely to include more than
  one "=" character in transactions, which is rejected by the e2e application.
* (critical, fixed) [#9581] - Absent prometheus label makes CometBFT crash
  when enabling Prometheus metric collection.
* (non-critical, not fixed) [#9548] - Full nodes can go over 50 connected
  peers, which is not intended by the default configuration.
* (non-critical, not fixed) [#9537] - With the default mempool cache setting,
  duplicated transactions are not rejected when gossiped and eventually flood
  all mempools. The 200 node testnets were thus run with a value of 200000 (as
  opposed to the default 10000).

## 200 Node Testnet

### Finding the Saturation Point

The first goal is to identify the saturation point and compare it with the baseline (v0.34.x).
For further details, see [this paragraph](/cometbft/latest/docs/qa/TMCore-QA-34#finding-the-saturation-point)
in the baseline version.

The following table summarizes the results for v0.37.x for the different experiments
(extracted from file [`v037_report_tabbed.txt`](https://raw.githubusercontent.com/cometbft/cometbft/v0.38.x/docs/qa/img37/200nodes_tm037/v037_report_tabbed.txt)).

The X axis of this table is `c`, the number of connections created by the load runner process to the target node.
The Y axis of this table is `r`, the rate or number of transactions issued per second.

|       |   c=1 |   c=2 |   c=4 |
| :---- | ----: | ----: | ----: |
| r=25  |  2225 |  4450 |  8900 |
| r=50  |  4450 |  8900 | 17800 |
| r=100 |  8900 | 17800 | 35600 |
| r=200 | 17800 | 35600 | 38660 |

For comparison, this is the table with the baseline version.

|       |   c=1 |   c=2 |   c=4 |
| :---- | ----: | ----: | ----: |
| r=25  |  2225 |  4450 |  8900 |
| r=50  |  4450 |  8900 | 17800 |
| r=100 |  8900 | 17800 | 35400 |
| r=200 | 17800 | 35600 | 37358 |

The saturation point is beyond the diagonal:

* `r=200,c=2`
* `r=100,c=4`

which is at the same place as the baseline. For more details on the saturation point, see
[this paragraph](/cometbft/latest/docs/qa/TMCore-QA-34#finding-the-saturation-point) in the baseline version.

The experiment chosen to examine Prometheus metrics is the same as in the baseline:
**`r=200,c=2`**.

The load runner's CPU load was negligible (near 0) when running `r=200,c=2`.

### Examining Latencies

The method described [here](/cometbft/latest/docs/qa/Method) allows us to plot the latencies of transactions
for all experiments.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_200node_latencies.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=319321574991f891e9ff5e6e819bbd06" alt="all-latencies" width="658" height="462" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_200node_latencies.png" />

The data seen in the plot is similar to that of the baseline.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_200node_latencies.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=d383b6f2dcce6932b4f8b8e1ee2c2d59" alt="all-latencies-bl" width="658" height="462" data-path="cometbft/latest/docs/qa/img34/v034_200node_latencies.png" />

Therefore, for further details on these plots,
see [this paragraph](/cometbft/latest/docs/qa/CometBFT-QA-34#examining-latencies) in the baseline version.

The following plot summarizes average latencies versus overall throughputs
across different numbers of WebSocket connections to the node into which
transactions are being loaded.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_latency_throughput.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=74054aef1d5e1f4421477f2d062af303" alt="latency-vs-throughput" width="640" height="480" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_latency_throughput.png" />

This is similar to the baseline plot:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_latency_throughput.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=ba58de5c6a6cfa253516efe9ef840bb2" alt="latency-vs-throughput-bl" width="640" height="480" data-path="cometbft/latest/docs/qa/img34/v034_latency_throughput.png" />

### Prometheus Metrics on the Chosen Experiment

As mentioned [above](#finding-the-saturation-point), the chosen experiment is `r=200,c=2`.
This section further examines key metrics for this experiment extracted from Prometheus data.

#### Mempool Size

The mempool size, a count of the number of transactions in the mempool, was shown to be stable and homogeneous
at all full nodes. It did not exhibit any unconstrained growth.
The plot below shows the evolution over time of the cumulative number of transactions inside all full nodes' mempools
at a given time.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_mempool_size.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=38467e7b8c9c91be80c551cdb7e0e547" alt="mempool-cumulative" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_mempool_size.png" />

The plot below shows the evolution of the average over all full nodes, which oscillates between 1500 and 2000 outstanding transactions.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_mempool_size_avg.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=2fae494eb371a033a780c962ed751769" alt="mempool-avg" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_mempool_size_avg.png" />

The peaks observed coincide with the moments when some nodes reached round 1 of consensus (see below).

**These plots yield similar results to the baseline**:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_mempool_size.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=e817046c6293ecb034e2f8f93b28a58f" alt="mempool-cumulative-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_mempool_size.png" />

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_mempool_size_avg.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=01d865f42e97083fff28f3d59364700a" alt="mempool-avg-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_mempool_size_avg.png" />

#### Peers

The number of peers was stable at all nodes.
It was higher for the seed nodes (around 140) than for the rest (between 16 and 78).

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_peers.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=97212d76cb53c7410caa4f00c81f0bea" alt="peers" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_peers.png" />

Just as in the baseline, the fact that non-seed nodes reach more than 50 peers is due to #9548.

**This plot yields similar results to the baseline**:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_peers.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=cef51aab2bfe76c05c8382363dd87371" alt="peers-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_peers.png" />

#### Consensus Rounds per Height

Most heights took just one round, but some nodes needed to advance to round 1 at some point.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_rounds.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=c4040ee67d46bf5c71fe2146626b67c9" alt="rounds" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_rounds.png" />

**This plot yields slightly better results than the baseline**:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_rounds.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=f22a9006537b891e92e16263c3747fb7" alt="rounds-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_rounds.png" />

#### Blocks Produced per Minute, Transactions Processed per Minute

The blocks produced per minute are the gradient of this plot.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_heights.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=48594e8d4b03e2016854345917c11042" alt="heights" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_heights.png" />

Over a period of 2 minutes, the height goes from 477 to 524.
This results in an average of 23.5 blocks produced per minute.

The transactions processed per minute are the gradient of this plot.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_total-txs.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=65cd1a03adfa5c234416df8b8a76355f" alt="total-txs" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_total-txs.png" />

Over a period of 2 minutes, the total goes from 64525 to 100125 transactions,
resulting in 17800 transactions per minute. However, we can see in the plot that
all transactions in the load are processed long before the two minutes.
If we adjust the time window when transactions are processed (approximately 90 seconds),
we obtain 23733 transactions per minute.

**These plots yield similar results to the baseline**:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_heights.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=bcc75df614e99c56e81b5958cf3e2d16" alt="heights-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_heights.png" />

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_total-txs.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=91ea5b509bb2ac0a08d75c52cff52e44" alt="total-txs" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_total-txs.png" />

#### Memory Resident Set Size

Resident Set Size of all monitored processes is plotted below.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_rss.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=92a0bd0c59c8b29eb600475cd84dcd6f" alt="rss" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_rss.png" />

The average over all processes oscillates around 380 MiB and does not demonstrate unconstrained growth.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_rss_avg.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=475bdda62cbf8fcfe08442e6eda63174" alt="rss-avg" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_rss_avg.png" />

**These plots yield similar results to the baseline**:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_rss.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=9a45ae9b6495f059fdb78c2ee72d6a88" alt="rss-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_rss.png" />

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_rss_avg.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=1fe277170d5f00df1fb5a8ee2043a40d" alt="rss-avg-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_rss_avg.png" />

#### CPU Utilization

The best metric from Prometheus to gauge CPU utilization in a Unix machine is `load1`,
as it usually appears in the
[output of `top`](https://www.digitalocean.com/community/tutorials/load-average-in-linux).

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_load1.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=5e7aab01509690b43cb7697ec5549fcf" alt="load1" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_r200c2_load1.png" />

It is contained below 5 on most nodes.

**This plot yields similar results to the baseline**:

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_r200c2_load1.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=83baea43c831678bd1327bee9984a35b" alt="load1" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_r200c2_load1.png" />

### Test Result

**Result: PASS**

Date: 2022-10-14

Version: 1cf9d8e276afe8595cba960b51cd056514965fd1

## Rotating Node Testnet

We use the same load as in the baseline: `c=4,r=800`.

Just as in the baseline tests, the version of CometBFT used for these tests is affected by #9539.
See this paragraph in the [baseline report](/cometbft/latest/docs/qa/Method#rotating-node-testnet) for further details.
Finally, note that this setup allows for a fairer comparison between this version and the baseline.

### Latencies

The plot of all latencies can be seen here.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_latencies.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=4ccb4d699e3260affd49da40defb840d" alt="rotating-all-latencies" width="658" height="462" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_latencies.png" />

This is similar to the baseline.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_latencies_uniq.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=60d7189aec99864554bfea72bea4ff07" alt="rotating-all-latencies-bl" width="658" height="462" data-path="cometbft/latest/docs/qa/img34/v034_rotating_latencies_uniq.png" />

Note that we are comparing against the baseline plot with *unique*
transactions. This is because the problem with duplicate transactions
detected during the baseline experiment did not show up for `v0.37`,
which is *not* proof that the problem is not present in `v0.37`.

### Prometheus Metrics

The set of metrics shown here match those shown on the baseline (`v0.34`) for the same experiment.
We also show the baseline results for comparison.

#### Blocks and Transactions per Minute

The blocks produced per minute are the gradient of this plot.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_heights.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=e65b678cfd18ce8301b2fe8822ac6cde" alt="rotating-heights" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_heights.png" />

Over a period of 4446 seconds, the height goes from 5 to 3323.
This results in an average of 45 blocks produced per minute,
which is similar to the baseline, shown below.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_heights.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=511dacb31496eed724f4eb6f6352b0ee" alt="rotating-heights-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_rotating_heights.png" />

The following two plots show only the heights reported by ephemeral nodes.
The second plot is the baseline plot for comparison.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_heights_ephe.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=670faae6e136c2749b18b817954fbd82" alt="rotating-heights-ephe" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_heights_ephe.png" />

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_heights_ephe.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=7b28802196854af36bc142ef68d4428f" alt="rotating-heights-ephe-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_rotating_heights_ephe.png" />

By the length of the segments, we can see that ephemeral nodes in `v0.37`
catch up slightly faster.

The transactions processed per minute are the gradient of this plot.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_total-txs.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=b8287fe61ecb429c740daaa1a8bcee22" alt="rotating-total-txs" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_total-txs.png" />

Over a period of 3852 seconds, the total goes from 597 to 267298 transactions in one of the validators,
resulting in 4154 transactions per minute, which is slightly lower than the baseline,
although the baseline had to deal with duplicate transactions.

For comparison, this is the baseline plot.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_total-txs.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=2bbb29a92196dfe11675ba13e2a68e67" alt="rotating-total-txs-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_rotating_total-txs.png" />

#### Peers

The plot below shows the evolution of the number of peers throughout the experiment.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_peers.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=76c7e915db14ba37c189a02474f14ce9" alt="rotating-peers" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_peers.png" />

This is the baseline plot, for comparison.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_peers.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=2310a5f9b9749cba2f570b6e61c5e792" alt="rotating-peers-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_rotating_peers.png" />

The plotted values and their evolution are comparable in both plots.

For further details on these plots, see the baseline report.

#### Memory Resident Set Size

The average Resident Set Size (RSS) over all processes looks slightly more stable
on `v0.37` (first plot) than on the baseline (second plot).

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_rss_avg.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=612d99cf203abd762005d35ad2854355" alt="rotating-rss-avg" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_rss_avg.png" />

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_rss_avg.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=804b8fcc38808f2b8d5c14d180aadd11" alt="rotating-rss-avg-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_rotating_rss_avg.png" />

The memory taken by the validators and the ephemeral nodes when they are up is comparable (not shown in the plots),
just as observed in the baseline.

#### CPU Utilization

The plot shows metric `load1` for all nodes.

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/onz-U_t6a1ypP_es/cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_load1.png?fit=max&auto=format&n=onz-U_t6a1ypP_es&q=85&s=46067e29db7617b4044b37bafae3ee48" alt="rotating-load1" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img37/200nodes_tm037/v037_rotating_load1.png" />

<img src="https://mintcdn.com/cosmos-docs-sync-security-docs/MgEE5qFncd6niaeC/cometbft/latest/docs/qa/img34/v034_rotating_load1.png?fit=max&auto=format&n=MgEE5qFncd6niaeC&q=85&s=e4e4093c0eb1736ce15c32dcc0167311" alt="rotating-load1-bl" width="2890" height="1000" data-path="cometbft/latest/docs/qa/img34/v034_rotating_load1.png" />

In both cases, it is contained under 5 most of the time, which is considered normal load.
The green line in the `v0.37` plot and the purple line in the baseline plot (`v0.34`)
correspond to the validators receiving all transactions, via RPC, from the load runner process.
In both cases, they oscillate around 5 (normal load). The main difference is that other
nodes are generally less loaded in `v0.37`.

### Test Result

**Result: PASS**

Date: 2022-10-10

Version: 155110007b9d8b83997a799016c1d0844c8efbaf

[#9533]: https://github.com/tendermint/tendermint/pull/9533

[#9534]: https://github.com/tendermint/tendermint/pull/9534

[#9539]: https://github.com/tendermint/tendermint/issues/9539

[#9548]: https://github.com/tendermint/tendermint/issues/9548

[#9537]: https://github.com/tendermint/tendermint/issues/9537

[#9581]: https://github.com/tendermint/tendermint/issues/9581
