Go to file
GroovieGermanikus f11d9c8309
add gso to client
2024-12-04 15:12:11 +01:00
.github/workflows adding ci job 2024-11-29 17:45:22 +01:00
block-builder toml version update 2024-11-18 14:32:01 +01:00
blocking_client add gso to client 2024-12-04 15:12:11 +01:00
client toml version update 2024-11-18 14:32:01 +01:00
common Quic optimization for laggy and non laggy clients 2024-11-27 10:18:57 +01:00
examples Quic optimization for laggy and non laggy clients 2024-11-27 10:18:57 +01:00
plugin toml version update 2024-11-18 14:32:01 +01:00
proxy toml version update 2024-11-18 14:32:01 +01:00
quiche toml version update 2024-11-18 14:32:01 +01:00
server visibility 2024-12-04 15:12:06 +01:00
.gitignore Creating 3 libraries, for plugin, client and common code between them 2024-05-10 11:46:04 +02:00
Cargo.lock toml version update 2024-11-18 14:32:01 +01:00
Cargo.toml toml version update 2024-11-18 14:32:01 +01:00
README.md Creating seperate filters for all accounts subscription and all transactions subscription 2024-05-19 19:35:35 +02:00
config.json Updating the version, and creating new tag 2024-11-18 12:35:40 +01:00
run_clippy_fmt.sh moving clippy to stable 1.76.0 2024-06-21 09:41:42 +02:00
rust-toolchain.toml Updating the version, and creating new tag 2024-11-18 12:35:40 +01:00

README.md

QUIC GEYSER PLUGIN

Solana geyser plugin which implements quic frontend for faster http-3 access of solana data.

Running Geyser

Compile and start the geyser plugin on a validator, and example config file is provided in config.json.

// To start a validator with geyser plugin add following argument to the solana validator
--geyser-plugin-config config.json

Client

Client can be configured like this :

use quic_geyser_client::client::Client;

let url = "127.0.0.1:10800"; // Address of quic plugin on the RPC
let client = Client::new( url, &Keypair::new(), ConnectionParameters::default())
        .await
        .unwrap();

// to subscribe updates for stake program, slots and blockmeta
client.subscribe(vec![
            Filter::Account(AccountFilter {
                owner: Some("Stake11111111111111111111111111111111111111"),
                accounts: None,
            }),
            Filter::Slot,
            Filter::BlockMeta,
        ])
        .await
        .unwrap();

You can also subscibe to all the account updates by using filter Filter::AccountsAll Similarly you can also subscibe to all transaction update by setting filter : Filter::TransactionsAll,.

Tester

Tester is an example program, which gets all the possible updates from quic server and tests the bandwidth used and lags wrt rest of the cluster.

You can run tester with following command.

cargo run --bin geyser-quic-plugin-tester --release -- -u ip_address:10800 -r rpc_address