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

Support for reducing disk space requirements #146

Merged
merged 3 commits into from
Nov 7, 2023
Merged

Conversation

mdehoog
Copy link
Contributor

@mdehoog mdehoog commented Nov 7, 2023

Add $OP_GETH_GCMODE and $OP_GETH_STATE_SCHEME envvars for overriding the --gcmode and --state.scheme op-geth arguments:

  • Setting OP_GETH_GCMODE=full allows people to run a full node instead of an archive node
  • Setting OP_GETH_STATE_SCHEME=path switches the ethereum state storage scheme to path (defaults to hash)

Also updates the README clarifying disk space requirements.

@mdehoog mdehoog force-pushed the michael/env-overrides branch from 7d70307 to d56e5b1 Compare November 7, 2023 17:49
@mdehoog mdehoog merged commit b497411 into main Nov 7, 2023
1 check passed
@mdehoog mdehoog deleted the michael/env-overrides branch November 7, 2023 17:58
@roberto-bayardo
Copy link
Contributor

FYI I tried syncing with state-scheme=path and ended up with a corrupted DB. Seems the geth devs have a patch for the issue but it's not in any release yet, and not clear when it will make its way into op-geth. I'd recommend NOT using it for now.

@adapt7
Copy link

adapt7 commented Apr 19, 2024

@roberto-bayardo @mdehoog sorry if question is dump but I had full node fully synced and added OP_GETH_STATE_SCHEME=path to the .env and rebuilt the docker. Should I wait for lower disk usage that will happen automatically or do I have to clear geth-data and re-sync from scrach?

@roberto-bayardo
Copy link
Contributor

roberto-bayardo commented Apr 19, 2024

If you changed state-scheme to PATH you'll need to delete the old DB for it to apply. it's a totally different DB format.

The real space saver though is to set OP_GETH_GCMODE=full

@adapt7
Copy link

adapt7 commented Apr 23, 2024

I set:

OP_NODE_SYNCMODE=execution-layer
OP_GETH_SYNCMODE=snap

and now there is zero connected peers after few days. What can be the problem?

If I change mode to full, isn't it the previous one that was by default? By looking at geth-entrypoint:

geth-entrypoint:OP_GETH_GCMODE="${OP_GETH_GCMODE:-full}"

It looks like "full" was default. What do you mean that changing to "full" is a space saver?

@roberto-bayardo
Copy link
Contributor

We're aware of the lack of peer availability for snap/execution sync, though don't have an ETA on a fix. In the meantime you may have to switch back to standard sync mode.

re: full, yes looks like it is the default now. It was archive at one point.

@adapt7
Copy link

adapt7 commented Apr 25, 2024

Now I understand, the defaults to "full" was introduced sometime earlier this month while I installed node before that so I had "archive", hence my node consumed over 3.5T disk space.

The "snap" mode still doesn't seem to work so I'm switching to "full".

@roberto-bayardo do you know how many blocks back the "full" node will offer to read data from? Is it this amount of blocks configurable? How about prune - is it implemented and "full" node will clear disk space at some point or only grow up heavily similar to archive node?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants