Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Exclude expired transactions when counting block size during block creation #13850

Merged
merged 88 commits into from
Jul 10, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
88 commits
Select commit Hold shift + click to select a range
60e8b87
Use proof queue asynchronously
vusirikala Jun 3, 2024
b56cc33
Committing what I have
vusirikala Jun 3, 2024
a369c28
Sending AddBatches message
vusirikala Jun 3, 2024
80a5a34
Calcuating the remaining txns
vusirikala Jun 3, 2024
4e5babe
Calculate proof queue size correctly
vusirikala Jun 4, 2024
1653475
Add a counter
vusirikala Jun 4, 2024
844e4ae
Update pfn_const_tps test
vusirikala Jun 4, 2024
be89d17
Minor changes
vusirikala Jun 4, 2024
8d77c78
Minor change
vusirikala Jun 5, 2024
e064652
Add some coutners
vusirikala Jun 5, 2024
204d823
Rust lint
vusirikala Jun 5, 2024
32eb5a4
Increasing quorum store backpressure limits
vusirikala Jun 5, 2024
7f63400
setting dynamic_min_txns_per_sec to 160
vusirikala Jun 5, 2024
196412f
Merge branch 'main' into satya/proof_queue
vusirikala Jun 6, 2024
76f9326
Fixing the calculation
vusirikala Jun 6, 2024
4c7af58
increase vfns to 7
vusirikala Jun 7, 2024
f71d2d0
Fixing the typo in batch generator
vusirikala Jun 7, 2024
2ee53a8
Merge branch 'main' into satya/proof_queue
vusirikala Jun 10, 2024
30490c3
Merge branch 'main' into satya/proof_queue
vusirikala Jun 11, 2024
e1dcb03
Merge branch 'main' into satya/proof_queue
vusirikala Jun 12, 2024
6282c44
Merge branch 'main' into satya/proof_queue
vusirikala Jun 13, 2024
29951a9
Add increase fraction
vusirikala Jun 13, 2024
cc3d7a2
Removing skipped transactions after inserting them
vusirikala Jun 13, 2024
5319f79
Add some counters
vusirikala Jun 13, 2024
a4f11ab
Update consensus pending duration counter
vusirikala Jun 13, 2024
eabe96c
Add more counters
vusirikala Jun 13, 2024
0c413fd
Increasing block size to 2500
vusirikala Jun 13, 2024
78b559b
Update a counter
vusirikala Jun 13, 2024
056baec
Increase block size limit
vusirikala Jun 13, 2024
6e54abb
Resetting execution config params
vusirikala Jun 14, 2024
685325a
Moving proof queue to utils.rs
vusirikala Jun 14, 2024
4a4d884
Moving counters
vusirikala Jun 14, 2024
a9871d8
Use transaction summary
vusirikala Jun 14, 2024
13669ca
intelligent pull proofs
vusirikala Jun 14, 2024
1264dad
Fix a bug in pull proofs
vusirikala Jun 15, 2024
5c38ea5
Merge branch 'main' into satya/proof_queue_simple
vusirikala Jun 15, 2024
244720c
Fix the bug
vusirikala Jun 15, 2024
7b0f5bc
Merge branch 'satya/proof_queue_simple' into satya/pull_proofs
vusirikala Jun 15, 2024
822746a
Rest to full to false in every iteration
vusirikala Jun 17, 2024
9982f97
Addressing PR comments
vusirikala Jun 17, 2024
3a23414
Move backpressure_tx to proof queue
vusirikala Jun 17, 2024
8c107be
Add info statement
vusirikala Jun 17, 2024
2f2e7a4
Merge branch 'satya/proof_queue_simple' into satya/pull_proofs
vusirikala Jun 17, 2024
75fabfe
Change buckets
vusirikala Jun 18, 2024
f20dd13
Add some info statements
vusirikala Jun 18, 2024
07aed02
Merge branch 'satya/proof_queue_simple' into satya/pull_proofs
vusirikala Jun 18, 2024
cb1b61d
Merge branch 'main' into satya/proof_queue_simple
vusirikala Jun 18, 2024
45b40bc
Merge branch 'main' into satya/proof_queue_simple
vusirikala Jun 18, 2024
51ccb9d
Cleanup
vusirikala Jun 19, 2024
9c76004
Remove an unrelated change
vusirikala Jun 19, 2024
21bb0ad
Addressing PR comments
vusirikala Jun 24, 2024
6eaafb2
Addressing PR comments
vusirikala Jun 25, 2024
46f18f3
Add some timer counters
vusirikala Jun 25, 2024
b0f73fd
Add more timer counters
vusirikala Jun 25, 2024
2bd92e2
Minor optimization
vusirikala Jun 25, 2024
51dc66b
Proof queue to be part of proof manager
vusirikala Jun 25, 2024
895cb79
Merge branch 'main' into satya/proof_queue_simple
vusirikala Jun 25, 2024
4a104c2
Move some code to a function
vusirikala Jun 25, 2024
bd3f611
Merge branch 'satya/proof_queue_simple' into satya/pull_proofs
vusirikala Jun 25, 2024
529e12a
Minor fixes
vusirikala Jun 26, 2024
f183611
Merge branch 'main' into satya/pull_proofs
vusirikala Jun 26, 2024
80aa8bf
Add max_unique_txns parameter
vusirikala Jun 26, 2024
5fce8e6
Use Lazy
vusirikala Jun 26, 2024
adbb6fc
Removing comments
vusirikala Jun 26, 2024
9964b60
Minor change
vusirikala Jun 26, 2024
0b170d3
Minor change
vusirikala Jun 26, 2024
d2f0fba
Minor fix
vusirikala Jun 26, 2024
13ec31b
Add unit test and address PR comments
vusirikala Jun 26, 2024
c428b1c
Minor fix in proof manager
vusirikala Jun 27, 2024
1d9b169
Merge branch 'main' into satya/pull_proofs
vusirikala Jun 27, 2024
2712880
Use saturating_sub
vusirikala Jun 27, 2024
0a50de4
Exclude expired transactions when counting block size
vusirikala Jun 27, 2024
b0c8aa2
Merge branch 'main' into satya/pull_proofs
vusirikala Jun 27, 2024
9d33742
Merge branch 'main' into satya/pull_proofs
vusirikala Jul 1, 2024
d92bca4
Merge branch 'satya/pull_proofs' into satya/count_unexpired
vusirikala Jul 1, 2024
a2a1c38
Minor fix
vusirikala Jul 1, 2024
12ec7b0
Addressing PR comments
vusirikala Jul 1, 2024
cdfbb17
Merge branch 'main' into satya/count_unexpired
vusirikala Jul 2, 2024
fe057ff
Minor fix
vusirikala Jul 2, 2024
1d6ace5
Change the expiration units
vusirikala Jul 9, 2024
9ef0610
Merge branch 'main' into satya/count_unexpired
vusirikala Jul 9, 2024
fcbf70c
Fixing unit tests
vusirikala Jul 10, 2024
cfad57f
Update unit tests
vusirikala Jul 10, 2024
5646d7e
renaming
vusirikala Jul 10, 2024
8ab96f4
Add block_timestamp as inputt to pull_proofs
vusirikala Jul 10, 2024
0a93374
Fix test
vusirikala Jul 10, 2024
45148be
Merge branch 'main' into satya/count_unexpired
vusirikala Jul 10, 2024
6bb88b7
Typo
vusirikala Jul 10, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fixing the calculation
  • Loading branch information
vusirikala committed Jun 6, 2024
commit 76f932670d58ed2055f62b7550b6688026b3b990
8 changes: 4 additions & 4 deletions consensus/src/quorum_store/counters.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
// SPDX-License-Identifier: Apache-2.0

use aptos_metrics_core::{
exponential_buckets, op_counters::DurationHistogram, register_avg_counter, register_histogram, register_histogram_vec, register_int_counter, register_int_counter_vec, register_int_gauge, Histogram, HistogramVec, IntCounter, IntCounterVec, IntGauge
exponential_buckets, op_counters::DurationHistogram, register_avg_counter, register_histogram,
register_histogram_vec, register_int_counter, register_int_counter_vec, register_int_gauge,
Histogram, HistogramVec, IntCounter, IntCounterVec, IntGauge,
};
use once_cell::sync::Lazy;
use std::time::Duration;
Expand Down Expand Up @@ -115,16 +117,14 @@ pub static TXNS_IN_PROOF_QUEUE: Lazy<IntGauge> = Lazy::new(|| {
.unwrap()
});

pub static PROOFS_IN_PROOF_QUEUE: Lazy<IntGauge> = Lazy::new(|| {
pub static PROOFS_IN_PROOF_QUEUE: Lazy<IntGauge> = Lazy::new(|| {
register_int_gauge!(
"quorum_store_proofs_in_proof_queue",
"Number of proofs in the proof queue"
)
.unwrap()
});



//////////////////////
// NEW QUORUM STORE
//////////////////////
Expand Down
54 changes: 31 additions & 23 deletions consensus/src/quorum_store/proof_queue.rs
Original file line number Diff line number Diff line change
Expand Up @@ -149,38 +149,22 @@ impl ProofQueue {

fn remaining_txns(&self) -> u64 {
// All the bath keys for which batch_to_proof is not None. This is the set of unexpired and uncommitted proofs.
let batch_keys = self
let unexpired_batch_keys = self
.batch_to_proof
.iter()
.filter_map(|(batch_key, proof)| proof.as_ref().map(|_| batch_key))
.filter(|(_, proof)| proof.is_some())
.map(|(batch_key, _)| batch_key)
.collect::<HashSet<_>>();
let mut remaining_txns = self
.txn_summary_to_batches
.iter()
.filter(|(_, batches)| {
batches
.iter()
.any(|batch_key| batch_keys.contains(batch_key))
.any(|batch_key| unexpired_batch_keys.contains(batch_key))
})
.count() as u64;

// count the number of batches with proofs but without txn summaries
counters::PROOFS_WITHOUT_BATCH_DATA.set(self.batch_to_proof.iter().map(|(batch_key, proof)| {
if proof.is_some() && !self.batches_with_txn_summary.contains(batch_key) {
1
} else {
0
}
}).sum::<i64>());

counters::PROOFS_IN_PROOF_QUEUE.set(self.batch_to_proof.iter().map(|(_, proof)| {
if proof.is_some() {
1
} else {
0
}
}).sum::<i64>());

// If a batch_key is not in batches_with_txn_summary, it means we've received the proof but haven't receive the
// transaction summary of the batch from batch coordinator. Add the number of txns in the batch to remaining_txns.
remaining_txns += self
Expand All @@ -196,12 +180,36 @@ impl ProofQueue {
.sum::<u64>();

//count the number of transactions with more than one batches
counters::TXNS_WITH_DUPLICATE_BATCHES.set(self.txn_summary_to_batches.iter().filter(|(_, batches)| {
batches.len() > 1
}).count() as i64);
counters::TXNS_WITH_DUPLICATE_BATCHES.set(
self.txn_summary_to_batches
.iter()
.filter(|(_, batches)| batches.len() > 1)
.count() as i64,
);

counters::TXNS_IN_PROOF_QUEUE.set(self.txn_summary_to_batches.len() as i64);

// count the number of batches with proofs but without txn summaries
counters::PROOFS_WITHOUT_BATCH_DATA.set(
self.batch_to_proof
.iter()
.map(|(batch_key, proof)| {
if proof.is_some() && !self.batches_with_txn_summary.contains(batch_key) {
1
} else {
0
}
})
.sum::<i64>(),
);

counters::PROOFS_IN_PROOF_QUEUE.set(
self.batch_to_proof
.values()
.map(|proof| if proof.is_some() { 1 } else { 0 })
.sum::<i64>(),
);

remaining_txns
}

Expand Down
Loading