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

header: hardening syncing logic #334

Merged
merged 64 commits into from
Jan 29, 2022
Merged

header: hardening syncing logic #334

merged 64 commits into from
Jan 29, 2022

Conversation

Wondertan
Copy link
Member

@Wondertan Wondertan commented Jan 10, 2022

Previously, we were syncing only once on Start and were catching up the chain by Pubsub topic. This PR changes that we can sync multiple times during runtime and if we missed some new Headers from PubSub topic, that will trigger sync again to catch-up. Also, this PR starts to verify new non-adjacent headers from PubSub and caches them to later be applied adjacently to avoid unnecessary request of already rcvd headers

Also fixes a variety of minor things.

Depends on #327
Closes: #242
Closes: #326

@Wondertan Wondertan force-pushed the hlib/sync-disconnects branch 4 times, most recently from aa88d6a to 2541ac2 Compare January 12, 2022 10:59
@Wondertan Wondertan changed the title header: slightly rework syncing logic header: hardening syncing logic Jan 12, 2022
Wondertan added a commit that referenced this pull request Jan 13, 2022
@Wondertan Wondertan marked this pull request as ready for review January 13, 2022 17:52
service/header/store.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
CHANGELOG-PENDING.md Outdated Show resolved Hide resolved
service/header/p2p_exchange.go Show resolved Hide resolved
service/header/p2p_subscriber.go Outdated Show resolved Hide resolved
service/header/store.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync_test.go Outdated Show resolved Hide resolved
service/header/sync_test.go Show resolved Hide resolved
@renaynay renaynay added the area:header Extended header label Jan 20, 2022
Copy link
Member

@liamsi liamsi left a comment

Choose a reason for hiding this comment

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

Generally looks very good. Left some comments and agree with @adlerjohn and most of @renaynay's comments.

service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Show resolved Hide resolved
service/header/sync.go Show resolved Hide resolved
service/header/verify.go Outdated Show resolved Hide resolved
Wondertan added a commit that referenced this pull request Jan 20, 2022
@Wondertan Wondertan force-pushed the hlib/sync-disconnects branch 3 times, most recently from f816e7c to 36caec9 Compare January 20, 2022 14:26
@Wondertan
Copy link
Member Author

I was changing network interfaces, hibernating, suspending for long, and still, my Light Node was syncing without needing to restart.

service/header/sync_ranges.go Outdated Show resolved Hide resolved
service/header/sync_ranges.go Outdated Show resolved Hide resolved
service/header/sync_ranges.go Outdated Show resolved Hide resolved
@Wondertan
Copy link
Member Author

Wondertan commented Jan 21, 2022

Changes since your last reviews

  • Handling of unbonding/trusting period for headers
    • Look at trustedHead
  • More refactorings and optimizations
  • Better logging
  • Better code comments

@Wondertan
Copy link
Member Author

Tests are failing due to known #340.

Copy link
Member

@renaynay renaynay left a comment

Choose a reason for hiding this comment

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

need to pass over it again tomorrow.

service/header/store.go Outdated Show resolved Hide resolved
Wondertan added a commit that referenced this pull request Jan 24, 2022
node/services/service.go Outdated Show resolved Hide resolved
service/header/core_exchange.go Show resolved Hide resolved
service/header/header_verify.go Show resolved Hide resolved
service/header/header_verify.go Show resolved Hide resolved
service/header/local_exchange.go Show resolved Hide resolved
service/header/sync_ranges.go Show resolved Hide resolved
service/header/sync_ranges.go Outdated Show resolved Hide resolved
service/header/sync_ranges.go Show resolved Hide resolved
service/header/sync_ranges.go Outdated Show resolved Hide resolved
service/header/sync_ranges.go Outdated Show resolved Hide resolved
.gitignore Show resolved Hide resolved
service/header/header_verify.go Show resolved Hide resolved
service/header/header_verify.go Show resolved Hide resolved
service/header/interface.go Outdated Show resolved Hide resolved
service/header/store.go Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
Wondertan added a commit that referenced this pull request Jan 25, 2022
Wondertan added a commit that referenced this pull request Jan 27, 2022
@Wondertan
Copy link
Member Author

There are two broken tests:

  • port already in use
    • not sure what to do with it
  • syncer related one:
    • this is type of flakeyness that will be fixed with younger bro PR, as it allows to wait for stuff instead of sleeps

@Bidon15 Bidon15 self-requested a review January 27, 2022 13:38
Bidon15
Bidon15 previously approved these changes Jan 27, 2022
Copy link
Member

@Bidon15 Bidon15 left a comment

Choose a reason for hiding this comment

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

Okay, let's go 👍

Copy link
Member

@renaynay renaynay left a comment

Choose a reason for hiding this comment

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

Almost ready.

service/header/interface.go Outdated Show resolved Hide resolved
service/header/interface.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
service/header/sync.go Outdated Show resolved Hide resolved
Co-authored-by: rene <41963722+renaynay@users.noreply.github.com>
Wondertan and others added 2 commits January 27, 2022 17:39
Co-authored-by: rene <41963722+renaynay@users.noreply.github.com>
Co-authored-by: rene <41963722+renaynay@users.noreply.github.com>
@Wondertan
Copy link
Member Author

@renaynay, responded

@renaynay
Copy link
Member

@Wondertan sir responded

@Wondertan
Copy link
Member Author

@renaynay, time to approve the behemoth beast

Bidon15
Bidon15 previously approved these changes Jan 27, 2022
@Wondertan
Copy link
Member Author

One of the suggestions broke the linter and I had to fix it, therefore I need reapprovals @Bidon15

Co-authored-by: rene <41963722+renaynay@users.noreply.github.com>
@Wondertan
Copy link
Member Author

Wondertan commented Jan 28, 2022

Broken test is a flakey one, but will be fixed by a younger bro

Copy link
Member

@renaynay renaynay left a comment

Choose a reason for hiding this comment

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

LEMS (let's end my suffering)

@Wondertan
Copy link
Member Author

Lol, no drama pls

Copy link
Member

@liamsi liamsi left a comment

Choose a reason for hiding this comment

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

Looks behemoth to me :D

But seriously, Thanks for tackling this, thanks fort the thorough reviews and for addressing all feedback.

I really hope we can split PRs like this into smaller PRs in the future.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area:header Extended header
Projects
No open projects
Archived in project
5 participants