diff options
author | Ava Chow <github@achow101.com> | 2024-09-04 11:40:26 -0400 |
---|---|---|
committer | Ava Chow <github@achow101.com> | 2024-09-04 11:40:26 -0400 |
commit | b8d2f58e06439e9523c02ca1729ff20cd0ba53ca (patch) | |
tree | 7dbc3c78a595016dd5f389c35d277c21dc0f2ead /doc | |
parent | f66011e88f6e265e2e1bd27d2add6f8076a6b719 (diff) | |
parent | a3108a7c5692d137b70b8442b4741936277e89be (diff) |
Merge bitcoin/bitcoin#30808: rpc: dumptxoutset height parameter follow-ups (29553)
a3108a7c5692d137b70b8442b4741936277e89be rpc: Manage dumptxoutset rollback with RAII class (Fabian Jahr)
c5eaae3b89c67c664c24a53908bea608785e481d doc: Add -rpcclienttimeout=0 to loadtxoutset examples (Fabian Jahr)
598b9bba5aa95d0b5f78ab90ac491f742819047a rpc: Don't re-enable previously disabled network after dumptxoutset (Fabian Jahr)
Pull request description:
First, this addresses two left-over comments in #29553:
- When running `dumptxoutset` the network gets disabled in the beginning and then re-enabled at the end. The network would be re-enabled even if the user had already disabled the network themself before running `dumptxoutset`. The network is now not re-enabled anymore since that might not be what the user wants.
- The `-rpcclienttimeout=0` option is added to `loadtxoutset` examples in documentation
Additionally, pablomartin4btc notified me that he found his node stuck at the invalidated height after some late testing after #29553 was merged. We could not find the actual source of the issue since his logs got lost. However, it seems likely that some kind of disruption stopped the process before the node could roll forward again. We fixed this issue for network disablement with a RAII class previously and it seems logical that this can happen the same way for the rollback part so I suggest to also fix it the same way.
An example to reproduce the issue described above as I think it happened: Remove the `!` in the following line in `PrepareUTXOSnapshot()` to simulate an issue occurring during `GetUTXOStats()`.
```
if (!maybe_stats) {
```
This leaves the node in the following state on master:
```
$ build/src/bitcoin-cli -rpcclienttimeout=0 -named dumptxoutset utxo-859750.dat rollback=859750
error code: -32603
error message:
Unable to read UTXO set
$ build/src/bitcoin-cli getchaintips
[
{
"height": 859762,
"hash": "00000000000000000002ec7a0fcca3aeca5b35545b52eb925766670aacc704ad",
"branchlen": 12,
"status": "headers-only"
},
{
"height": 859750,
"hash": "0000000000000000000010897b6b88a18f9478050200d8d048013c58bfd6229e",
"branchlen": 0,
"status": "active"
},
```
(Note that the first tip is `headers-only` and not `invalid` only because I started `dumptxoutset` before my node had fully synced to the tip. pablomartin4btc saw it as `invalid`.)
ACKs for top commit:
maflcko:
re-ACK a3108a7c5692d137b70b8442b4741936277e89be 🐸
achow101:
ACK a3108a7c5692d137b70b8442b4741936277e89be
pablomartin4btc:
cr ACK a3108a7c5692d137b70b8442b4741936277e89be
Tree-SHA512: d2ab32f62de2253312e27d7d753ec0995da3fe7a22ffc3d6c7cfa3b68a4a144c59210aa82b7a704c2a29c3b2aad6ea74972e3e8bb979ee4b7082a20f4bfddc9c
Diffstat (limited to 'doc')
-rw-r--r-- | doc/assumeutxo.md | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/doc/assumeutxo.md b/doc/assumeutxo.md index 4584eebf43..2b3f2bac47 100644 --- a/doc/assumeutxo.md +++ b/doc/assumeutxo.md @@ -17,7 +17,7 @@ Once you've obtained the snapshot, you can use the RPC command `loadtxoutset` to load it. ``` -$ bitcoin-cli loadtxoutset /path/to/input +$ bitcoin-cli -rpcclienttimeout=0 loadtxoutset /path/to/input ``` After the snapshot has loaded, the syncing process of both the snapshot chain |