-
Notifications
You must be signed in to change notification settings - Fork 87
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
Verkle gossip - initial thoughts #299
Comments
Requiring nodes to execute blocks might be too costly in terms of cpu and/or bandwidth for this too be a requirement for nodes... something that we should measure... but this does make for a nice mechanism even if we can't make all of the nodes participate... even a few nodes don't this in the network could be enough to generate the head state data needed for all of the other nodes that don't have the cpu/bandwidth to spare
…-------- Original Message --------
On 5/12/24 2:58 AM, Milos Stankovic wrote:
We can always do the same strategy that we plan to do for MPT, but I wanted to document some ideas that are only possible with Verkle.
Main idea - stateless execution
In post-Verkle, we can execute blocks without having entire state. It would be powerful to utilize this property and lower requirements for the bridges.
Gossiping single block/epoch
The stateless execution gives us all trie changes. This means that for every modified/created trie node, we have previous and new value of every accessed child.
This is enough to calculate the trie node commitments/hashes and verify state root, but not enough to gossip to Portal Network (you need all children). In order to do that, we need the trie node from before block is executed, which we could potentially find within Portal Network itself. The advantage is that we don't have to rely on finding all the trie nodes, but we can update and gossip only nodes that are already present in the network.
This should be done in epochs (not per block), in order to better utilize requesting data from Portal Network.
Note: Similar approach can be applied for MPT as well, but we would have to find all accessed trie nodes within Portal Network (otherwise we can't execute the block).
Missing trie nodes recovery
One of the weaknesses of this approach is that we rely on finding trie nodes inside Portal Network. Per trie node, steps look like this:
- get trie node at block N from Portal Network
- execute block N+1
- update the trie node
- gossip the trie node at N+1 to Portal Network
If we can't find some trie nodes at block N, we can still execute the block, and update and gossip other trie nodes.
But we can also try to recreate missing trie nodes. We can try to get missing trie nodes from block N+1, apply reverse changes, and gossip them to the network (for block N).
Use head state to gossip archive state
We were already discussing having two types of state networks:
- head - path based, access to state for most recent (e.g. 256) blocks
- archive - hash based, access to entire archive state
The design of head state network is in very early stage. However, it's likely that only content that has to be gossiped to each node is the block header and execution proof. That should be enough for each node to update its own head state.
Once each node updates its head state, it can gossip it to the archive network.
This would remove the need for bridges to gossip archive state for the head of the blockchain, and be used only for older states (e.g. as outlined above).
—
Reply to this email directly, [view it on GitHub](#299), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AAGJHASYQKUZKQQQOGLFSNLZB4VJZAVCNFSM6AAAAABHSUL7PKVHI2DSMVQWIX3LMV43ASLTON2WKOZSGI4TCMRTGM2DOOI).
You are receiving this because you are subscribed to this thread.Message ID: ***@***.***>
|
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
We can always do the same strategy that we plan to do for MPT, but I wanted to document some ideas that are only possible with Verkle.
Main idea - stateless execution
In post-Verkle, we can execute blocks without having entire state. It would be powerful to utilize this property and lower requirements for the bridges.
Gossiping single block/epoch
The stateless execution gives us all trie changes. This means that for every modified/created trie node, we have previous and new value of every accessed child.
This is enough to calculate the trie node commitments/hashes and verify state root, but not enough to gossip to Portal Network (you need all children). In order to do that, we need the trie node from before block is executed, which we could potentially find within Portal Network itself. The advantage is that we don't have to rely on finding all the trie nodes, but we can update and gossip only nodes that are already present in the network.
This should be done in epochs (not per block), in order to better utilize requesting data from Portal Network.
Note: Similar approach can be applied for MPT as well, but we would have to find all accessed trie nodes within Portal Network (otherwise we can't execute the block).
Missing trie nodes recovery
One of the weaknesses of this approach is that we rely on finding trie nodes inside Portal Network. Per trie node, steps look like this:
If we can't find some trie nodes at block N, we can still execute the block, and update and gossip other trie nodes.
But we can also try to recreate missing trie nodes. We can try to get missing trie nodes from block N+1, apply reverse changes, and gossip them to the network (for block N).
Use head state to gossip archive state
We were already discussing having two types of state networks:
The design of head state network is in very early stage. However, it's likely that only content that has to be gossiped to each node is the block header and execution proof. That should be enough for each node to update its own head state.
Once each node updates its head state, it can gossip it to the archive network.
This would remove the need for bridges to gossip archive state for the head of the blockchain, and be used only for older states (e.g. as outlined above).
The text was updated successfully, but these errors were encountered: