forked from solana-labs/solana
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement QUIC connection warmup service for future leaders (solana-l…
…abs#24054) * Increase connection timeouts * Bump quic connection cache to 1024 * Use constant for quic connection timeout and add warm cache service * Fixes to QUIC warmup service * fix check failure * fixes after rebase * fix timeout test Co-authored-by: Pankaj Garg <pankaj@solana.com>
- Loading branch information
Showing
7 changed files
with
153 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
// Connect to future leaders with some jitter so the quic connection is warm | ||
// by the time we need it. | ||
|
||
use { | ||
rand::{thread_rng, Rng}, | ||
solana_client::connection_cache::send_wire_transaction, | ||
solana_gossip::cluster_info::ClusterInfo, | ||
solana_poh::poh_recorder::PohRecorder, | ||
std::{ | ||
sync::{ | ||
atomic::{AtomicBool, Ordering}, | ||
Arc, Mutex, | ||
}, | ||
thread::{self, sleep, Builder, JoinHandle}, | ||
time::Duration, | ||
}, | ||
}; | ||
|
||
pub struct WarmQuicCacheService { | ||
thread_hdl: JoinHandle<()>, | ||
} | ||
|
||
// ~50 seconds | ||
const CACHE_OFFSET_SLOT: i64 = 100; | ||
const CACHE_JITTER_SLOT: i64 = 20; | ||
|
||
impl WarmQuicCacheService { | ||
pub fn new( | ||
cluster_info: Arc<ClusterInfo>, | ||
poh_recorder: Arc<Mutex<PohRecorder>>, | ||
exit: Arc<AtomicBool>, | ||
) -> Self { | ||
let thread_hdl = Builder::new() | ||
.name("sol-warm-quic-service".to_string()) | ||
.spawn(move || { | ||
let slot_jitter = thread_rng().gen_range(-CACHE_JITTER_SLOT, CACHE_JITTER_SLOT); | ||
let mut maybe_last_leader = None; | ||
while !exit.load(Ordering::Relaxed) { | ||
if let Some(leader_pubkey) = poh_recorder | ||
.lock() | ||
.unwrap() | ||
.leader_after_n_slots((CACHE_OFFSET_SLOT + slot_jitter) as u64) | ||
{ | ||
if maybe_last_leader | ||
.map_or(true, |last_leader| last_leader != leader_pubkey) | ||
{ | ||
maybe_last_leader = Some(leader_pubkey); | ||
if let Some(addr) = cluster_info | ||
.lookup_contact_info(&leader_pubkey, |leader| leader.tpu) | ||
{ | ||
if let Err(err) = send_wire_transaction(&[0u8], &addr) { | ||
warn!( | ||
"Failed to warmup QUIC connection to the leader {:?}, Error {:?}", | ||
leader_pubkey, err | ||
); | ||
} | ||
} | ||
} | ||
} | ||
sleep(Duration::from_millis(200)); | ||
} | ||
}) | ||
.unwrap(); | ||
Self { thread_hdl } | ||
} | ||
|
||
pub fn join(self) -> thread::Result<()> { | ||
self.thread_hdl.join() | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters