proxy: improve docs
This commit is contained in:
parent
7f9f9f4a4e
commit
98673e5bc0
|
@ -10,7 +10,7 @@ protocol on behalf of the web browser. Running full solana [validators](https://
|
|||
is incredibly resource intensive `(>256GB RAM)`, the goal of this
|
||||
project would be to create a specialized micro-service that allows
|
||||
to deploy this logic quickly and allows [horizontal scalability](https://en.wikipedia.org/wiki/Scalability) with
|
||||
commodity vms.
|
||||
commodity vms. Optionally the Lite RCP micro-services can be configured to send the transactions to a complementary __QUIC forward proxy__ instead of the solana tpu ([details](quic-forward-proxy/README.md)).
|
||||
|
||||
### Confirmation strategies
|
||||
|
||||
|
|
|
@ -1,11 +1,37 @@
|
|||
|
||||
Purpose
|
||||
-------
|
||||
This component (__quic-forward-proxy__) can be optionally used along with one or multiple Lite RPC micro-service instances.
|
||||
The Lite RPC services need to be reconfigured to send transactions via __quic-forward-proxy__ instead of sending them directly to the solana tpu nodes.
|
||||
|
||||
Benefits:
|
||||
* the __quic-forward-proxy__ can batch transactions from multiple source and send them efficiently to the solana validator
|
||||
* the __quic-forward-proxy__ can be configured with a validator identity keypair
|
||||
* connections to TPU will be privileged (__staked connections__)
|
||||
* keypair can be kept in one place while the Lite RPC instances can benefit from the staked connection
|
||||
|
||||
|
||||
Configuration
|
||||
---------------------
|
||||
Prepare: choose a proxy port (e.g. 11111) and bind address of appropriate (minimal) network interface (e.g. 127.0.0.1)
|
||||
1. run quic proxy
|
||||
```
|
||||
# unstaked
|
||||
solana-lite-rpc-quic-forward-proxy --proxy-listen-addr 127.0.0.1:11111
|
||||
# staked
|
||||
solana-lite-rpc-quic-forward-proxy --proxy-listen-addr 127.0.0.1:11111 --identity-keypair /pathto-test-ledger/validator-keypair.json
|
||||
```
|
||||
2. run lite-rpc
|
||||
```bash
|
||||
lite-rpc --experimental-quic-proxy-addr 127.0.0.1:11111
|
||||
```
|
||||
|
||||
|
||||
Architecture Overview
|
||||
---------------------
|
||||
```
|
||||
+------------+ +------------+ +------------+ +------------+
|
||||
| | | | | | | |
|
||||
| bench | ---1---> | lite-rpc | ---2---> | proxy | ---3---> | validator |
|
||||
| client | ---1---> | lite-rpc | ---2---> | proxy | ---3---> | validator |
|
||||
| | | | | | | |
|
||||
+------------+ +------------+ +------------+ +------------+
|
||||
|
||||
|
@ -13,28 +39,54 @@
|
|||
2. tpu forward proxy request (QUIC): transactions, tpu address and tpu identity
|
||||
3. tpu call (QUIC), transactions:
|
||||
|
||||
* client: RPC client to lite-rpc
|
||||
* proxy: QUIC forward proxy service (one instance)
|
||||
* lite-rpc: N lite-rpc services
|
||||
* validator: solana validator (TPU) according to the leader schedule
|
||||
|
||||
```
|
||||
|
||||
Local Development / Testing
|
||||
---------------------------
|
||||
### Rust Integration Test
|
||||
|
||||
Use integrated testing in __quic_proxy_tpu_integrationtest.rs__.
|
||||
|
||||
### Local Setup With Solana Test Validator
|
||||
1. run test-validator (tested with 1.16.1)
|
||||
```bash
|
||||
RUST_LOG="error,solana_streamer::nonblocking::quic=debug" solana-test-validator --log
|
||||
```
|
||||
3. run quic proxy
|
||||
```bash
|
||||
RUST_LOG=debug cargo run --bin solana-lite-rpc-quic-forward-proxy -- --proxy-listen-addr 0.0.0.0:11111 --identity-keypair /pathto-test-ledger/validator-keypair.json
|
||||
```
|
||||
2. run lite-rpc
|
||||
```bash
|
||||
RUST_LOG=debug cargo run --bin lite-rpc -- --experimental-quic-proxy-addr 127.0.0.1:11111
|
||||
```
|
||||
3. run rust bench tool in _lite-rpc_
|
||||
```bash
|
||||
cd bench; cargo run -- --tx-count=10
|
||||
```
|
||||
```bash
|
||||
RUST_LOG="error,solana_streamer::nonblocking::quic=debug" solana-test-validator --log
|
||||
```
|
||||
2. run quic proxy
|
||||
```bash
|
||||
# unstaked
|
||||
RUST_LOG=debug cargo run --bin solana-lite-rpc-quic-forward-proxy -- --proxy-listen-addr 0.0.0.0:11111
|
||||
# staked
|
||||
RUST_LOG=debug cargo run --bin solana-lite-rpc-quic-forward-proxy -- --proxy-listen-addr 0.0.0.0:11111 --identity-keypair /pathto-test-ledger/validator-keypair.json
|
||||
```
|
||||
3. run lite-rpc
|
||||
```bash
|
||||
RUST_LOG=debug cargo run --bin lite-rpc -- --experimental-quic-proxy-addr 127.0.0.1:11111
|
||||
```
|
||||
4. run rust bench tool in _lite-rpc_
|
||||
```bash
|
||||
cd bench; cargo run -- --tx-count=10
|
||||
```
|
||||
|
||||
Implementation Details
|
||||
----------------------
|
||||
* the __proxy__ is designed to be light-weight and stateless (no persistence)
|
||||
* note: only one instance of the __proxy__ should talk to the TPU nodes at a time to be able to correctly comply with the validator quic policy
|
||||
* outbound connections (to TPU):
|
||||
* __proxy__ tries to maintain active quic connections to recent TPU nodes
|
||||
* __proxy__ will maintain multiple quic connection per TPU according to the solána validator quic policy
|
||||
* __proxy__ will use lightweight quic streams to send the transactions
|
||||
* inbound traffic (from Lite RPC)
|
||||
* __proxy__ supports only quic ATM but that could be extended to support other protocols
|
||||
* __proxy__ will perform client authentication by TLS (see [issue](https://github.com/blockworks-foundation/lite-rpc/issues/167))
|
||||
* TPU selection / Leader Schedule
|
||||
* the __proxy__ will not perform any TPU selection; the TPU target nodes __MUST__ be selected by the __client__ (Lite RPC) and not by the __proxy__
|
||||
* pitfall: the TPU target node list might become stale if the transactions are not sent out fast enough
|
||||
|
||||
### Example Output from _Solana Validator_:
|
||||
(note: the peer type is __Staked__)
|
||||
|
@ -46,8 +98,10 @@ cd bench; cargo run -- --tx-count=10
|
|||
[2023-06-26T15:16:18.430854000Z DEBUG solana_streamer::nonblocking::quic] stream error: ApplicationClosed(ApplicationClose { error_code: 0, reason: b"done" })
|
||||
```
|
||||
|
||||
solana validator quic policy
|
||||
----------------------------
|
||||
TPU has complex logic to assign connection capacity to TPU clients; this considers stake vs unstaked connections, per peer/per node limits, QUIC stream limits (see solana quic.rs)
|
||||
|
||||
QUIC/QUINN Endpoint and Connection specifics
|
||||
---------------------------
|
||||
* keep-alive and idle timeout: both values must be aligned AND they must be configured on both endpoints (see [docs](https://docs.rs/quinn/latest/quinn/struct.TransportConfig.html#method.keep_alive_interval))
|
||||
* tune or disable __max_concurrent_uni_streams__ respectively
|
||||
Project Info
|
||||
----------------
|
||||
* [Lite RPC](https://github.com/blockworks-foundation/lite-rpc/)
|
Loading…
Reference in New Issue