-
Notifications
You must be signed in to change notification settings - Fork 212
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Lower overhead for the solo-to-chain communication path #3763
Comments
It's possible to hash events into Tendermint headers allowing for light client proofs. I can go look for an example but this issue is a place to start |
Looks like that proposal was declined: https://github.com/tendermint/tendermint/blob/master/docs/architecture/adr-058-event-hashing.md#status Or do you know of something coming up? |
There were some flaws in I feel like they could addressed for this use case |
@dtribble just noted cosmos/cosmos-sdk#10045
|
I did some more testing, and found that the next bottleneck for RPC nodes is suboptimal Tendermint locking: tendermint/tendermint#6899. The benchmarks I've done there by removing some (apparently unnecessary) locks show that we should be able to get ~2800 queries/second out of each RPC node. Between that and Agoric-specific optimisations (like this issue's proposed use of Tendermint events to notify clients), there is light at the end of the tunnel. I hope it's not an approaching train. :) |
We have landed a working version of this plan. Block verification has further to go, but that's already tracked in #3803. |
What is the Problem Being Solved?
Our goal is to use IBC between the solo machine (the private off-chain client that connects to the chain and sends transactions to manipulate private and public objects) and the chain #1670. This may take significant time to do, and we want our solo communications to be more scalable in the meantime.
The main problem is that the Cosmos RPC nodes cannot answer RPC queries while running the JS VM as part of EndBlock.
We want the JS VM output to be available to the AppHash, but not prevent RPCs sent by independent solos. The current implementation of ag-solo subscribes to the new block events, and polls the on-chain mailbox (i.e. makes a
ag-cosmos-helper query swingset mailbox agoric1...
call) on every new block. This runs amok of the global ABCI lock tendermint/tendermint#6899, since N ag-solos put a load of N queries per block on the RPC nodes and those RPC nodes are spending around 8 seconds in EndBlock.Description of the Design
We will move more of the work into Tendermint events, whose subscription is not subject to the ABCI lock, even though the WebSocket that subscribes uses the same port (26657) to which the other RPC queries are made.
Security Considerations
The
chain-cosmos-sdk.js
communication does not do any light client verification. We need that feature from CosmJS and/or the solo-IBC relayer we choose to use. Until then, our solo client trusts the RPC server it connects to.Fixing this would entail putting commitments to messages outbound from the chain in the KVStore, fetching them, and verifying their Merkle proofs before we accept a packet from the chain.
Test Plan
Create a test network with many ag-solos connected to it and verify that the RPC node stays responsive.
The text was updated successfully, but these errors were encountered: