monero/src/blockchain_utilities/README.md

89 lines
2.2 KiB
Markdown
Raw Normal View History

# Monero Blockchain Utilities
2024-05-21 16:29:33 +00:00
Copyright (c) 2014-2024, The Monero Project
## Introduction
2016-09-03 19:54:10 +00:00
The blockchain utilities allow one to import and export the blockchain.
## Usage:
See also each utility's "--help" option.
2016-09-03 19:54:10 +00:00
### Export an existing blockchain database
2016-09-03 19:54:10 +00:00
`$ monero-blockchain-export`
2016-09-03 19:54:10 +00:00
This loads the existing blockchain and exports it to `$MONERO_DATA_DIR/export/blockchain.raw`
### Import the exported file
2016-09-03 19:54:10 +00:00
`$ monero-blockchain-import`
2016-09-03 19:54:10 +00:00
This imports blocks from `$MONERO_DATA_DIR/export/blockchain.raw` (exported using the
`monero-blockchain-export` tool as described above) into the current database.
Defaults: `--batch on`, `--batch size 20000`, `--verify on`
Batch size refers to number of blocks and can be adjusted for performance based on available RAM.
Verification should only be turned off if importing from a trusted blockchain.
If you encounter an error like "resizing not supported in batch mode", you can just re-run
2016-09-03 19:54:10 +00:00
the `monero-blockchain-import` command again, and it will restart from where it left off.
```bash
## use default settings to import blockchain.raw into database
2016-09-03 19:54:10 +00:00
$ monero-blockchain-import
## fast import with large batch size, database mode "fastest", verification off
2016-09-03 19:54:10 +00:00
$ monero-blockchain-import --batch-size 20000 --database lmdb#fastest --verify off
```
### Import options
`--input-file`
specifies input file path for importing
default: `<data-dir>/export/blockchain.raw`
`--output-file`
specifies output file path to export to
default: `<data-dir>/export/blockchain.raw`
`--block-stop`
stop at block number
`--database <database type>`
`--database <database type>#<flag(s)>`
database type: `lmdb, memory`
flags:
The flag after the # is interpreted as a composite mode/flag if there's only
one (no comma separated arguments).
The composite mode represents multiple DB flags and support different database types:
`safe, fast, fastest`
Database-specific flags can be set instead.
LMDB flags (more than one may be specified):
`nosync, nometasync, writemap, mapasync, nordahead`
## Examples:
```bash
2016-09-03 19:54:10 +00:00
$ monero-blockchain-import --database lmdb#fastest
2016-09-03 19:54:10 +00:00
$ monero-blockchain-import --database lmdb#nosync
$ monero-blockchain-import --database lmdb#nosync,nometasync
```