Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Notification-based block pinning #13157

Merged
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
d5c1427
Worker
skunert Dec 22, 2022
6131598
Reorganize and unpin onnotification drop
skunert Jan 6, 2023
ccdf8ed
Pin in state-db, pass block number
skunert Jan 9, 2023
0443235
Pin blocks in blockchain db
skunert Jan 10, 2023
c1a25dc
Switch to reference counted LRU
skunert Jan 10, 2023
9d824d4
Merge branch 'master' into skunert/notification-based-pinning
skunert Jan 10, 2023
2f7f943
Disable pinning when we keep all blocks
skunert Jan 11, 2023
65caa1a
Fix pinning hint for state-db
skunert Jan 12, 2023
cc000a3
Remove pinning from backend layer
skunert Jan 12, 2023
8a22325
Improve readability
skunert Jan 12, 2023
d3d208a
Add justifications to test
skunert Jan 12, 2023
bc2d40c
Fix justification behaviour
skunert Jan 12, 2023
da7a855
Remove debug prints
skunert Jan 12, 2023
7daf11c
Convert channels to tracing_unbounded
skunert Jan 16, 2023
2fb995c
Add comments to the test
skunert Jan 16, 2023
7a072dd
Documentation and Cleanup
skunert Jan 16, 2023
92e3928
Move task start to client
skunert Jan 16, 2023
3ec854e
Simplify cache
skunert Jan 16, 2023
d5e2b1d
Improve test, remove unwanted log
skunert Jan 16, 2023
03051ca
Add tracing logs, remove expect for block number
skunert Jan 16, 2023
c4434bb
Cleanup
skunert Jan 16, 2023
347c80a
Add conversion method for unpin handle to Finalitynotification
skunert Jan 17, 2023
1198568
Revert unwanted changes
skunert Jan 17, 2023
363f01a
Improve naming
skunert Jan 17, 2023
b220553
Make clippy happy
skunert Jan 17, 2023
10dfdf7
Fix docs
skunert Jan 17, 2023
e2ff001
Merge branch 'master' into skunert/notification-based-pinning
skunert Jan 17, 2023
c4608da
Use `NumberFor` instead of u64 in API
skunert Jan 17, 2023
68cc76f
Hand over weak reference to unpin worker task
skunert Jan 17, 2023
fe2d4cc
Unwanted
skunert Jan 17, 2023
f5d6b08
&Hash -> Hash
skunert Jan 17, 2023
946e06a
Remove number from interface, rename `_unpin_handle`, LOG_TARGET
skunert Jan 18, 2023
a48e44b
Move RwLock one layer up
skunert Jan 18, 2023
4014c16
Apply code style suggestions
skunert Jan 18, 2023
d547fc2
Improve comments
skunert Jan 18, 2023
de6aa36
Replace lru crate by schnellru
skunert Jan 18, 2023
81f7493
Merge remote-tracking branch 'origin' into skunert/notification-based…
skunert Jan 19, 2023
6fa6d5c
Only insert values for pinned items + better docs
skunert Jan 19, 2023
a177b50
Apply suggestions from code review
skunert Jan 19, 2023
cbd0868
Improve comments, log target and test
skunert Jan 19, 2023
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
Improve readability
  • Loading branch information
skunert committed Jan 12, 2023
commit 8a223253fb414d2bf76c508de467e9211cc5550d
75 changes: 52 additions & 23 deletions client/db/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ use log::{debug, trace, warn};
use lru::LruCache;
use parking_lot::{Mutex, RwLock};
use std::{
collections::{hash_map::Entry, HashMap, HashSet},
collections::{HashMap, HashSet},
io,
num::NonZeroUsize,
path::{Path, PathBuf},
Expand Down Expand Up @@ -478,9 +478,35 @@ fn cache_header<Hash: std::cmp::Eq + std::hash::Hash, Header>(
}
}

struct PinnedBlockCacheEntry<V> {
ref_count: u32,
pub value: Option<V>,
}

impl<V> Default for PinnedBlockCacheEntry<V> {
fn default() -> Self {
Self { ref_count: 0, value: None }
}
}

impl<V> PinnedBlockCacheEntry<V> {
pub fn decrease_ref(&mut self) {
self.ref_count = self.ref_count.saturating_sub(1);
}

pub fn increase_ref(&mut self) {
self.ref_count = self.ref_count.saturating_add(1);
}

pub fn has_no_references(&self) -> bool {
self.ref_count == 0
}
}

struct PinnedBlockCache<Block: BlockT> {
body_cache: RwLock<LruCache<Block::Hash, (u32, Option<Option<Vec<Block::Extrinsic>>>)>>,
justification_cache: RwLock<LruCache<Block::Hash, (u32, Option<Option<Justifications>>)>>,
body_cache: RwLock<LruCache<Block::Hash, PinnedBlockCacheEntry<Option<Vec<Block::Extrinsic>>>>>,
justification_cache:
RwLock<LruCache<Block::Hash, PinnedBlockCacheEntry<Option<Justifications>>>>,
}

impl<Block: BlockT> PinnedBlockCache<Block> {
Expand All @@ -494,12 +520,12 @@ impl<Block: BlockT> PinnedBlockCache<Block> {

pub fn bump_ref(&self, hash: Block::Hash) {
let mut body_cache = self.body_cache.write();
let mut entry = body_cache.get_or_insert_mut(hash, || (0, None));
entry.0 += 1;
let entry = body_cache.get_or_insert_mut(hash, Default::default);
entry.increase_ref();

let mut justification_cache = self.justification_cache.write();
let mut entry = justification_cache.get_or_insert_mut(hash, || (0, None));
entry.0 += 1;
let entry = justification_cache.get_or_insert_mut(hash, Default::default);
entry.increase_ref();
}

pub fn contains(&self, hash: &Block::Hash) -> bool {
skunert marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -514,44 +540,44 @@ impl<Block: BlockT> PinnedBlockCache<Block> {
justifications: Option<Justifications>,
) {
let mut body_cache = self.body_cache.write();
let mut entry = body_cache.get_or_insert_mut(hash, || (0, None));
entry.1 = Some(extrinsics);
let mut entry = body_cache.get_or_insert_mut(hash, Default::default);
entry.value = Some(extrinsics);

let mut justification_cache = self.justification_cache.write();
let mut entry = justification_cache.get_or_insert_mut(hash, || (0, None));
entry.1 = Some(justifications);
let mut entry = justification_cache.get_or_insert_mut(hash, Default::default);
entry.value = Some(justifications);
}

pub fn remove(&self, hash: &Block::Hash) {
let mut body_cache = self.body_cache.write();
if let Some(mut entry) = body_cache.peek_mut(hash) {
entry.0 = entry.0.saturating_sub(1);
if entry.0 == 0 {
if let Some(entry) = body_cache.peek_mut(hash) {
entry.decrease_ref();
if entry.has_no_references() {
body_cache.pop(hash);
}
}

let mut justification_cache = self.justification_cache.write();
if let Some(mut entry) = justification_cache.peek_mut(hash) {
entry.0 = entry.0.saturating_sub(1);
if entry.0 == 0 {
if let Some(entry) = justification_cache.peek_mut(hash) {
entry.decrease_ref();
if entry.has_no_references() {
justification_cache.pop(hash);
}
}
}

pub fn justification(&self, hash: &Block::Hash) -> Option<Option<Justifications>> {
let justification_cache = self.justification_cache.read();
if let Some(result) = justification_cache.peek(hash) {
return result.1.clone()
if let Some(cache_entry) = justification_cache.peek(hash) {
return cache_entry.value.clone()
};
None
}

pub fn body(&self, hash: &Block::Hash) -> Option<Option<Vec<Block::Extrinsic>>> {
let body_cache = self.body_cache.read();
if let Some(result) = body_cache.peek(hash) {
return result.1.clone()
if let Some(cache_entry) = body_cache.peek(hash) {
return cache_entry.value.clone()
};
None
}
Expand Down Expand Up @@ -4180,7 +4206,8 @@ pub(crate) mod tests {

prev_hash = hash;
}
// Block 1 gets pinned twice
// Block 1 gets pinned three times
backend.pin_block(&blocks[1], 1).unwrap();
backend.pin_block(&blocks[1], 1).unwrap();

let mut op = backend.begin_operation().unwrap();
Expand Down Expand Up @@ -4210,7 +4237,9 @@ pub(crate) mod tests {
assert!(bc.body(blocks[2]).unwrap().is_none());
assert!(bc.body(blocks[3]).unwrap().is_none());

// After this second unpin, block 1 should be removed
// After these unpins, block 1 should be removed
backend.unpin_block(&blocks[1]);
assert!(bc.body(blocks[1]).unwrap().is_some());
backend.unpin_block(&blocks[1]);
assert!(bc.body(blocks[1]).unwrap().is_none());

Expand Down