- If you use
verbose(or-vargument), switch tolog_filters(orRUST_LOGenvironment variable). Please note that it allows to set per-module filters, but module naming is considered unstable. If you have used-vv(the value suggested in the documentation), switch to--log-filters INFO:
| Log filter | Old verbose value |
Description |
|---|---|---|
| ERROR | 0 | Only fatal errors |
| WARN | 1 | Things that could indicate serious problems |
| INFO | 2 | Various significant events and suggestions |
| DEBUG | 3 | Details that could be useful when debugging - only use when debugging! |
| TRACE | 4 | Very detailed information - only use when debugging! |
In 0.9.0 we have changed the RocksDB index format to optimize electrs performance. We also use Bitcoin P2P protocol instead of reading blocks from disk or JSON RPC. Some guides were suggesting trace log level and we started to trace much more information.
Upgrading checklist:
- Make sure you upgrade at time when you don't need to use electrs for a while.
Because of reindex electrs will be unable to serve your requests for a few hours.
(The exact time depends on your hardware.)
If you wish to check the database without reindexing run electrs with
--no-auto-reindex. - If you have less than 60 GB of free space delete
mainnetsubdirectory inside yourdb_dirbefore running the new version. Note however if you have less than 60 GB of free space you should consider extending your storage soon since in the worst case scenario you will run out of space in ~100 days. - Make sure to allow accesses to bitcoind from local address, ideally whitelist it using
whitelist=download@127.0.0.1bitcoind option. Either don't usemaxconnectionsbitcoind option or set it to 12 or more. - If you use non-default P2P port (or address) for bitcoind adjust
electrsconfiguration. - If you still didn't migrate
cookieelectrs option you have to now - see below. - Remove unsupported options from configuration (
blocks_dir,jsonrpc_import,bulk_index_threads,tx_cache_size_mb,blocktxids_cache_size_mb) - Rename
txid_limittoindex_lookup_limitiif used - If you use
verbose = 4(or-vvvvargument) lower it down to2(-vv) for production use. Keeping it would waste resources because we utilize it more now. - After reindexing, if you did not delete
mainnetsubdirectory withindb_dircheck thatelectrsworks as expected and then delete wholemainnetsubdirectory. - If you are using our Dockerfile, please make sure to re-map the DB volume (see the section above).
If you're upgrading from version 0.8.7 to a higher version and used cookie option you should change your configuration!
The cookie option was deprecated and will be removed eventually!
If you had actual cookie (from ~/bitcoin/.cookie file) specified in cookie option, this was wrong as it wouldn't get updated when needed.
It's strongly recommended to use proper cookie authentication using cookie_file.
If you really have to use fixed username and password, explicitly specified in bitcoind config, use auth option instead.
Users of btc-rpc-proxy using public:public need to use auth too.
You can read a detailed explanation of cookie deprecation with motivation explained.
As with any other application, you need to remember how you installed electrs to upgrade it.
If you don't then here's a little help: run which electrs and compare the output
- If you got an error you didn't install
electrsinto your system in any way, it's probably sitting in thetarget/releasedirectory of source - If the path starts with
/bin/then either you have used packaging system or you made a mistake the first time (non-packaged binaries must go to/usr/local/bin) - If the path starts with
/usr/local/binyou most likely copied electrs there after building - If the path starts with
/home/YOUR_USERNAME/.cargo/binyou most likely rancargo install
If you used Debian packaging system you only need this:
sudo apt update
sudo apt upgrade
Similarly for other distributions - use their respective commands.
If a new version of electrs is not yet in the package system, try wait a few days or contact the maintainers of the packages if it's been a long time.
- Enter your
electrssource directory, usually in~/but some people like to put it in something like~/sources. If you've deleted it, you need togit cloneagain. git checkout mastergit pull- Strongly recommended:
git verify-tag v0.9.1(fix the version number if we've forgotten to update the docs ;)) should show "Good signature from 15C8 C357 4AE4 F1E2 5F3F 35C5 87CA E5FA 4691 7CBB" git checkout v0.9.1- If you used static linking:
cargo build --locked --release. If you used dynamic linkingROCKSDB_INCLUDE_DIR=/usr/include ROCKSDB_LIB_DIR=/usr/lib cargo build --locked --release. If you don't remember which linking you used, you probably used static. This step will take a few tens of minutes (but dynamic linking is a bit faster), go grab a coffee. Also remember that you need enough free RAM, the build will die otherwise - If you've previously copied
electrsinto/usr/local/binrun: sudocp target/release/electrs /usr/local/binIf you've previously installedelectrsusingcargo install:cargo install --locked --path . -f - If you've manually configured systemd service:
sudo systemctl restart electrs