Skip to content
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

feat(dot/sync): Implement warp sync strategy #4275

Open
wants to merge 44 commits into
base: development
Choose a base branch
from

Conversation

dimartiro
Copy link
Contributor

@dimartiro dimartiro commented Oct 22, 2024

Changes

Implementation of the warp sync strategy.
This strategy is composed of 2 phases:

  1. Request warp sync proofs until get one completed proof (last finalized block)
  2. Retrieve that block to be used later for the state sync strategy

This goal of this strategy is to reach the latest finalized block of the canonical chain following authority set changes and validating justifications.
After this block is reached, we have to retrieve its state using the state_sync, that will allow us to build blocks on top of that one while we fill the gap between genesis and the latest finalized block retrieved by the warp sync.

Summary of changes

  • Add new warp_sync strategy
    • Add required warp sync p2p messages
    • Add new reputation changes constants
  • Refactor peer set view to share the same reference between the strategies
  • Add CLI config to use warp sync instead of full sync when node is started
  • Tests

Tests

make test

Issues

closes: #3183, #4277

@dimartiro dimartiro self-assigned this Oct 22, 2024
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch from 20937f7 to 6a553fb Compare October 24, 2024 13:29
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch 2 times, most recently from da62fed to 7ad8347 Compare October 31, 2024 13:12
@dimartiro dimartiro marked this pull request as ready for review October 31, 2024 22:10
Copy link
Member

@EclesioMeloJunior EclesioMeloJunior left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! 🚀

dot/sync/service.go Show resolved Hide resolved
dot/sync/warp_sync.go Show resolved Hide resolved
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch from c2789d6 to 93108f7 Compare November 5, 2024 13:34
Copy link
Contributor

@haikoschol haikoschol left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just a few nits/questions but LGTM!

dot/sync/service.go Show resolved Hide resolved
dot/sync/warp_sync.go Outdated Show resolved Hide resolved
dot/sync/warp_sync.go Outdated Show resolved Hide resolved
dot/sync/warp_sync.go Outdated Show resolved Hide resolved
dot/sync/warp_sync.go Outdated Show resolved Hide resolved
lib/common/hash.go Outdated Show resolved Hide resolved
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch from 014395d to 42faaf7 Compare November 10, 2024 08:27
dot/network/messages/warp_sync_test.go Outdated Show resolved Hide resolved
dot/network/messages/warp_sync.go Outdated Show resolved Hide resolved
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch from 42faaf7 to 89dcb62 Compare November 15, 2024 08:22
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch 3 times, most recently from 967a77e to 7294e7d Compare December 5, 2024 09:47
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch from 7294e7d to a3ee839 Compare December 9, 2024 15:03
@P1sar P1sar added the A-in-QA-or-regression pull request or issues is currently in QA or regression testing phase. label Dec 12, 2024
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch 4 times, most recently from 6004faf to a1b63c3 Compare December 19, 2024 13:27
@dimartiro dimartiro force-pushed the diego/warpsync/strategy branch from 2402582 to adfaa59 Compare January 16, 2025 01:18
@dimartiro dimartiro added the A-in-QA-or-regression pull request or issues is currently in QA or regression testing phase. label Jan 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-blocked issue or PR is blocked until something else changes. A-in-QA-or-regression pull request or issues is currently in QA or regression testing phase. C-complex Complex changes across multiple modules. Possibly will require additional research. S-sync-kusama related to particular network syncing. S-sync-paseo related to particular network syncing. S-sync-polkadot related to particular network syncing. S-sync-westend related to particular network syncing.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Implement warp sync strategy
5 participants