Skip to content
This repository has been archived by the owner on Jan 22, 2025. It is now read-only.

Commit

Permalink
Plumb Entry notification into plugin manager (#30910)
Browse files Browse the repository at this point in the history
Plumb entry notification into plugin manager
  • Loading branch information
Tyera authored Mar 28, 2023
1 parent 1f420f2 commit 9323015
Show file tree
Hide file tree
Showing 9 changed files with 122 additions and 1 deletion.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions geyser-plugin-manager/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ jsonrpc-server-utils = { workspace = true }
libloading = { workspace = true }
log = { workspace = true }
serde_json = { workspace = true }
solana-entry = { workspace = true }
solana-geyser-plugin-interface = { workspace = true }
solana-measure = { workspace = true }
solana-metrics = { workspace = true }
Expand Down
76 changes: 76 additions & 0 deletions geyser-plugin-manager/src/entry_notifier.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
/// Module responsible for notifying plugins about entries
use {
crate::geyser_plugin_manager::GeyserPluginManager,
log::*,
solana_entry::entry::Entry,
solana_geyser_plugin_interface::geyser_plugin_interface::{
ReplicaEntryInfo, ReplicaEntryInfoVersions,
},
solana_measure::measure::Measure,
solana_metrics::*,
solana_rpc::entry_notifier_interface::EntryNotifier,
solana_sdk::clock::Slot,
std::sync::{Arc, RwLock},
};

pub(crate) struct EntryNotifierImpl {
plugin_manager: Arc<RwLock<GeyserPluginManager>>,
}

impl EntryNotifier for EntryNotifierImpl {
fn notify_entry<'a>(&'a self, slot: Slot, index: usize, entry: &'a Entry) {
let mut measure = Measure::start("geyser-plugin-notify_plugins_of_entry_info");

let plugin_manager = self.plugin_manager.read().unwrap();
if plugin_manager.plugins.is_empty() {
return;
}

let entry_info = Self::build_replica_entry_info(slot, index, entry);

for plugin in plugin_manager.plugins.iter() {
if !plugin.entry_notifications_enabled() {
continue;
}
match plugin.notify_entry(ReplicaEntryInfoVersions::V0_0_1(&entry_info)) {
Err(err) => {
error!(
"Failed to notify entry, error: ({}) to plugin {}",
err,
plugin.name()
)
}
Ok(_) => {
trace!("Successfully notified entry to plugin {}", plugin.name());
}
}
}
measure.stop();
inc_new_counter_debug!(
"geyser-plugin-notify_plugins_of_entry_info-us",
measure.as_us() as usize,
10000,
10000
);
}
}

impl EntryNotifierImpl {
pub fn new(plugin_manager: Arc<RwLock<GeyserPluginManager>>) -> Self {
Self { plugin_manager }
}

fn build_replica_entry_info(
slot: Slot,
index: usize,
entry: &'_ Entry,
) -> ReplicaEntryInfo<'_> {
ReplicaEntryInfo {
slot,
index,
num_hashes: entry.num_hashes,
hash: entry.hash.as_ref(),
executed_transaction_count: entry.transactions.len() as u64,
}
}
}
10 changes: 10 additions & 0 deletions geyser-plugin-manager/src/geyser_plugin_manager.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,16 @@ impl GeyserPluginManager {
false
}

/// Check if there is any plugin interested in entry data
pub fn entry_notifications_enabled(&self) -> bool {
for plugin in &self.plugins {
if plugin.entry_notifications_enabled() {
return true;
}
}
false
}

/// Admin RPC request handler
pub(crate) fn list_plugins(&self) -> JsonRpcResult<Vec<String>> {
Ok(self.plugins.iter().map(|p| p.name().to_owned()).collect())
Expand Down
21 changes: 20 additions & 1 deletion geyser-plugin-manager/src/geyser_plugin_service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ use {
accounts_update_notifier::AccountsUpdateNotifierImpl,
block_metadata_notifier::BlockMetadataNotifierImpl,
block_metadata_notifier_interface::BlockMetadataNotifierLock,
entry_notifier::EntryNotifierImpl,
geyser_plugin_manager::{GeyserPluginManager, GeyserPluginManagerRequest},
slot_status_notifier::SlotStatusNotifierImpl,
slot_status_observer::SlotStatusObserver,
Expand All @@ -11,6 +12,7 @@ use {
crossbeam_channel::Receiver,
log::*,
solana_rpc::{
entry_notifier_interface::EntryNotifierLock,
optimistically_confirmed_bank_tracker::BankNotification,
transaction_notifier_interface::TransactionNotifierLock,
},
Expand All @@ -30,6 +32,7 @@ pub struct GeyserPluginService {
plugin_manager: Arc<RwLock<GeyserPluginManager>>,
accounts_update_notifier: Option<AccountsUpdateNotifier>,
transaction_notifier: Option<TransactionNotifierLock>,
entry_notifier: Option<EntryNotifierLock>,
block_metadata_notifier: Option<BlockMetadataNotifierLock>,
}

Expand Down Expand Up @@ -74,6 +77,7 @@ impl GeyserPluginService {
let account_data_notifications_enabled =
plugin_manager.account_data_notifications_enabled();
let transaction_notifications_enabled = plugin_manager.transaction_notifications_enabled();
let entry_notifications_enabled = plugin_manager.entry_notifications_enabled();
let plugin_manager = Arc::new(RwLock::new(plugin_manager));

let accounts_update_notifier: Option<AccountsUpdateNotifier> =
Expand All @@ -93,10 +97,20 @@ impl GeyserPluginService {
None
};

let entry_notifier: Option<EntryNotifierLock> = if entry_notifications_enabled {
let entry_notifier = EntryNotifierImpl::new(plugin_manager.clone());
Some(Arc::new(RwLock::new(entry_notifier)))
} else {
None
};

let (slot_status_observer, block_metadata_notifier): (
Option<SlotStatusObserver>,
Option<BlockMetadataNotifierLock>,
) = if account_data_notifications_enabled || transaction_notifications_enabled {
) = if account_data_notifications_enabled
|| transaction_notifications_enabled
|| entry_notifications_enabled
{
let slot_status_notifier = SlotStatusNotifierImpl::new(plugin_manager.clone());
let slot_status_notifier = Arc::new(RwLock::new(slot_status_notifier));
(
Expand Down Expand Up @@ -124,6 +138,7 @@ impl GeyserPluginService {
plugin_manager,
accounts_update_notifier,
transaction_notifier,
entry_notifier,
block_metadata_notifier,
})
}
Expand All @@ -146,6 +161,10 @@ impl GeyserPluginService {
self.transaction_notifier.clone()
}

pub fn get_entry_notifier(&self) -> Option<EntryNotifierLock> {
self.entry_notifier.clone()
}

pub fn get_block_metadata_notifier(&self) -> Option<BlockMetadataNotifierLock> {
self.block_metadata_notifier.clone()
}
Expand Down
1 change: 1 addition & 0 deletions geyser-plugin-manager/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
pub mod accounts_update_notifier;
pub mod block_metadata_notifier;
pub mod block_metadata_notifier_interface;
pub mod entry_notifier;
pub mod geyser_plugin_manager;
pub mod geyser_plugin_service;
pub mod slot_status_notifier;
Expand Down
1 change: 1 addition & 0 deletions programs/sbf/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 11 additions & 0 deletions rpc/src/entry_notifier_interface.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
use {
solana_entry::entry::Entry,
solana_sdk::clock::Slot,
std::sync::{Arc, RwLock},
};

pub trait EntryNotifier {
fn notify_entry(&self, slot: Slot, index: usize, entry: &Entry);
}

pub type EntryNotifierLock = Arc<RwLock<dyn EntryNotifier + Sync + Send>>;
1 change: 1 addition & 0 deletions rpc/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#![allow(clippy::integer_arithmetic)]
mod cluster_tpu_info;
pub mod entry_notifier_interface;
pub mod max_slots;
pub mod optimistically_confirmed_bank_tracker;
pub mod parsed_token_accounts;
Expand Down

0 comments on commit 9323015

Please sign in to comment.