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

builder/multiarch #2480

Draft
wants to merge 248 commits into
base: master
Choose a base branch
from
Draft
Changes from 5 commits
Commits
Show all changes
248 commits
Select commit Hold shift + click to select a range
0b4c7e9
rename bootnode yaml files
rjonczy Feb 16, 2023
0751a02
fix: peer chain size
mfrankovi Feb 20, 2023
276a983
chore: fix segfault on network test
MatusKysel Feb 21, 2023
368167f
Merge pull request #2336 from Taraxa-project/peer_chain_size
mfrankovi Feb 22, 2023
f09752b
chore: set min. delegationt o 1k TARA and starting validators delegat…
JakubFornadel Feb 23, 2023
7afb12a
Merge pull request #2341 from Taraxa-project/adjust-devnet-config
JakubFornadel Feb 23, 2023
821f96d
chore: set default delegation for our validators to 100k
JakubFornadel Feb 24, 2023
1a09cc9
Merge branch 'develop' into adjust-devnet-config
JakubFornadel Feb 24, 2023
e364f9c
Merge pull request #2342 from Taraxa-project/adjust-devnet-config
JakubFornadel Feb 24, 2023
49d1747
ignore helm stuff
rjonczy Feb 22, 2023
7abd8c3
wip: enable to deploy different images
rjonczy Feb 22, 2023
d7c1b0f
fix yaml to json
rjonczy Feb 22, 2023
445d78a
added taraxa-indexer
rjonczy Feb 24, 2023
6331e5b
fix indexer image keys
rjonczy Feb 24, 2023
dd8afee
ws
rjonczy Feb 24, 2023
193a08c
temp chage of tag
rjonczy Feb 24, 2023
114a395
enable indexer
rjonczy Feb 24, 2023
c5461dc
fix volume name
rjonczy Feb 24, 2023
d085348
chore: fix incorrect error log in rewards distribution
mfrankovi Feb 26, 2023
9971877
Merge pull request #2345 from Taraxa-project/fix_err_log
mfrankovi Feb 27, 2023
c3816ec
Merge branch 'develop' into network-test-segfault
MatusKysel Feb 27, 2023
4f6d9ac
deploy specific version
rjonczy Feb 27, 2023
2460587
Merge pull request #2337 from Taraxa-project/network-test-segfault
MatusKysel Feb 27, 2023
eb4a2ea
changed tag of indexer
rjonczy Feb 27, 2023
4934191
changed indexer image
rjonczy Feb 27, 2023
14d871a
fix args for taraxa-indexer
rjonczy Feb 27, 2023
5de622a
set nodeSelector for nodes in prnet
rjonczy Feb 27, 2023
a11f0b1
added ingress for indexer
rjonczy Feb 27, 2023
7b9173b
fix name for indexer
rjonczy Feb 27, 2023
a24e9d5
add annotation for indexer ingress
rjonczy Feb 27, 2023
10636d8
add missing port
rjonczy Feb 27, 2023
6d1393b
fix port
rjonczy Feb 27, 2023
208dbfc
added indexer to github comment
rjonczy Feb 28, 2023
c4275a2
removed temp tag
rjonczy Feb 28, 2023
ee164e3
remove tag from indexer on ci pipeline
rjonczy Feb 28, 2023
1fa0075
fix pullPolicy key
rjonczy Feb 28, 2023
6a5b406
added affinity-mode as annotation
rjonczy Feb 28, 2023
fd29815
move part of .gitignore helm chart folder
rjonczy Feb 28, 2023
9d94897
Merge branch 'develop' into chart/v0.3.3
rjonczy Feb 28, 2023
9edea9f
Merge pull request #2344 from Taraxa-project/chart/v0.3.3
rjonczy Feb 28, 2023
10f571b
chore: use old version of conan
MatusKysel Feb 28, 2023
fc9bc32
Merge pull request #2350 from Taraxa-project/fix-buidling-develop
MatusKysel Feb 28, 2023
6106192
chore: update dependencies
MatusKysel Feb 28, 2023
67821ed
Merge pull request #2354 from Taraxa-project/update-dependencies
MatusKysel Mar 1, 2023
1c75bc7
chore: vote sync error log remove
mfrankovi Feb 26, 2023
0fd99c5
Merge pull request #2346 from Taraxa-project/vote_sync_err_log
mfrankovi Mar 1, 2023
c037d49
chore: add ValidatorExists flag into Undelegation struct returned fro…
JakubFornadel Feb 28, 2023
9b91d3b
Merge pull request #2351 from Taraxa-project/issue-2347/fix_get_undel…
JakubFornadel Mar 1, 2023
bbd34ee
fix: update evm submodule with correct address in dpos_contract logs
kstdl Mar 1, 2023
d42876a
chore: adds cors config for indexer
rattrap Mar 2, 2023
db82bd0
Merge pull request #2362 from Taraxa-project/indexer-cors-config
rattrap Mar 2, 2023
2732aac
chore: fix transfer_lot_of_blocks test
MatusKysel Mar 2, 2023
ceeea7d
chore: refactor transaction exceptions
MatusKysel Mar 3, 2023
d428742
Merge pull request #2365 from Taraxa-project/fix-network-test
MatusKysel Mar 3, 2023
6622148
Merge branch 'develop' into fix_dpos_logs_address
kstdl Mar 3, 2023
6a71b26
Merge branch 'develop' into transaction-exception
MatusKysel Mar 3, 2023
2949d29
Merge pull request #2361 from Taraxa-project/fix_dpos_logs_address
kstdl Mar 3, 2023
54dbb97
feat: add transactions hashes to newHead event
kstdl Mar 1, 2023
af0dc41
feat: add taraxa_getChainStats moethod to RPC
kstdl Mar 1, 2023
8feaa05
Merge pull request #2356 from Taraxa-project/rpc_improvements
kstdl Mar 3, 2023
fcc872f
Merge branch 'develop' into transaction-exception
MatusKysel Mar 3, 2023
9be004a
Merge pull request #2366 from Taraxa-project/transaction-exception
MatusKysel Mar 3, 2023
d32f107
added changelog entry for chart
rjonczy Mar 6, 2023
b1472a9
changed db_path to data_dir
rjonczy Mar 6, 2023
18dc3ea
bump chart version
rjonczy Mar 6, 2023
2f51c9e
updated changelog for helm-chart
rjonczy Mar 6, 2023
8fff258
Merge pull request #2371 from Taraxa-project/chart/v0.3.5
rjonczy Mar 6, 2023
334177e
chore: implement claimAllRewards function in dpos contract
JakubFornadel Mar 2, 2023
a949579
chore: update evm
JakubFornadel Mar 6, 2023
01abfbb
chore: update evm
JakubFornadel Mar 6, 2023
fa699dd
Merge pull request #2364 from Taraxa-project/issue-2358/implement_cla…
JakubFornadel Mar 7, 2023
3a3b45e
chore: update do cpp-check 2.10
MatusKysel Mar 6, 2023
168fb1b
chore: cppcheck useStlAlgorithm
MatusKysel Mar 6, 2023
b753b08
chore: cppcheck remove cstyled casts
MatusKysel Mar 6, 2023
c28e4b7
Merge pull request #2368 from Taraxa-project/cpp-check
MatusKysel Mar 7, 2023
6a5d35e
fix: missing tip block on tips selection
mfrankovi Mar 6, 2023
5e66cc1
Merge pull request #2367 from Taraxa-project/tip_block_missing
mfrankovi Mar 7, 2023
a301284
chore: random light node prune interval
mfrankovi Mar 7, 2023
6740aa8
remove disabled test
MatusKysel Mar 8, 2023
45d644a
Merge pull request #2373 from Taraxa-project/light_node_interval
mfrankovi Mar 8, 2023
996da35
chore: remove HF functionality
MatusKysel Mar 8, 2023
4fb94ad
Merge branch 'develop' into remove-test
MatusKysel Mar 8, 2023
1cd08a7
Merge pull request #2375 from Taraxa-project/remove-test
MatusKysel Mar 8, 2023
73545ab
Merge branch 'develop' into remove-hf
MatusKysel Mar 8, 2023
1c75893
Merge pull request #2376 from Taraxa-project/remove-hf
MatusKysel Mar 8, 2023
61325a8
chore: apart from previous period cert votes and previous round next …
JakubFornadel Mar 7, 2023
b561223
fix: process votes bundle even if some of the votes were already proc…
JakubFornadel Mar 7, 2023
9cff2b1
Merge pull request #2374 from Taraxa-project/issue-2372/fix_votes_syn…
JakubFornadel Mar 9, 2023
ff83ae2
Empty-Commit
rjonczy Mar 9, 2023
b582cee
Merge pull request #2377 from Taraxa-project/chore/test-of-merge-queu…
rjonczy Mar 9, 2023
3708c64
chore: optimize prune
mfrankovi Mar 9, 2023
c7e0b90
Merge pull request #2378 from Taraxa-project/prune_opt
mfrankovi Mar 9, 2023
9a4f4af
feat: remove duplicated columns from DB
MatusKysel Mar 9, 2023
70f0be7
chore: asynchronous prune of state_db
mfrankovi Mar 10, 2023
6b44faa
Merge pull request #2380 from Taraxa-project/storage-improvements
MatusKysel Mar 10, 2023
672388c
chore: remove unrelevant test + other code related to this test
JakubFornadel Mar 7, 2023
2426ddb
chore: wait 100ms before going into second finishing steo
JakubFornadel Mar 7, 2023
420d012
refactor: rename variables and remove unsued code
JakubFornadel Mar 7, 2023
d4c163e
chore: trigger exponentail backoff only if node is too far behind the…
JakubFornadel Mar 9, 2023
5dc72ce
chore: fix round_determine_from_next_votes test
JakubFornadel Mar 10, 2023
52ff614
Merge pull request #2379 from Taraxa-project/issue-2318/fix_exponenti…
JakubFornadel Mar 10, 2023
63dd433
Merge pull request #2381 from Taraxa-project/async_prune
mfrankovi Mar 13, 2023
8cf4043
fix: build on arm macs that was broken after update of cppcheck
kstdl Mar 14, 2023
eadfc89
chore: fix building instructions
MatusKysel Mar 14, 2023
0f0b68a
Merge pull request #2383 from Taraxa-project/fix-building-instructions
MatusKysel Mar 14, 2023
ff589b7
chore: optimize rewards votes handling
mfrankovi Feb 28, 2023
341a0c2
Merge pull request #2352 from Taraxa-project/syncing_optimization
mfrankovi Mar 15, 2023
b4a0a60
feat: implement eip-1898
MatusKysel Mar 16, 2023
35ffa41
fix: do not broadcast votes that were not processed + request pbft sy…
JakubFornadel Mar 16, 2023
5aac615
fix: request votes syncing only if packet sender == vote author
JakubFornadel Mar 16, 2023
0b76a36
Merge pull request #2386 from Taraxa-project/fix_peer_chainsize
JakubFornadel Mar 16, 2023
a7da136
chore: introduce HACK for json-rpc function params overloading
MatusKysel Mar 16, 2023
293a7a9
chore: disable gen_rpc_stubs
MatusKysel Mar 16, 2023
2245bc8
chore: modify rest of the API calls to accept int for block num
MatusKysel Mar 16, 2023
217aaf7
Merge branch 'develop' into eip-1898
MatusKysel Mar 16, 2023
80b8f12
Merge pull request #2387 from Taraxa-project/eip-1898
MatusKysel Mar 16, 2023
8ad4b47
remove rpc nodes
rjonczy Mar 17, 2023
84c1424
chore: fix replacing nodes from table
MatusKysel Mar 18, 2023
1d2079e
Merge pull request #2392 from Taraxa-project/chore/remove-rpc-from-bo…
rjonczy Mar 19, 2023
f9cbfdb
fix processVote return value check
JakubFornadel Mar 20, 2023
a1e84ed
fix: cpp-check warnings on build
kstdl Mar 21, 2023
9fcbc67
Merge pull request #2382 from Taraxa-project/fix_mac_build
kstdl Mar 21, 2023
dacb4a6
chore: fix rebuilding db columns
MatusKysel Mar 21, 2023
aa09ea6
Merge pull request #2399 from Taraxa-project/fix-votes-processing
JakubFornadel Mar 22, 2023
6325649
Merge pull request #2403 from Taraxa-project/fix_cppcheck
kstdl Mar 22, 2023
42991cd
fix: RLP InvalidEncodingSize inherits from RLPException
kstdl Mar 22, 2023
d7f693d
fix: formating for clang-format
kstdl Mar 22, 2023
089e9ae
Merge pull request #2406 from Taraxa-project/fix_rlp_exception
kstdl Mar 22, 2023
9ed0039
Merge pull request #2405 from Taraxa-project/fix-db-column-rebuild
MatusKysel Mar 22, 2023
f722213
added kubemonkey labels
rjonczy Mar 23, 2023
caee001
parametrize kubemonkey
rjonczy Mar 23, 2023
dd23f4b
fix keys
rjonczy Mar 23, 2023
680c223
updated changelod
rjonczy Mar 23, 2023
73883c0
scrape from taraxa-indexer
rjonczy Mar 23, 2023
142b2f6
added quotes to labels' values
rjonczy Mar 23, 2023
c52667e
Merge pull request #2411 from Taraxa-project/chart/v0.3.X
rjonczy Mar 23, 2023
3409596
chore: adds transaction generating script
rattrap Mar 16, 2023
49c13e3
Merge pull request #2415 from Taraxa-project/chart/v0.3.7
rattrap Mar 23, 2023
ee499ca
Merge branch 'develop' into chart/v0.3.8
rjonczy Mar 24, 2023
931fde2
bump version
rjonczy Mar 24, 2023
210d844
Merge pull request #2412 from Taraxa-project/chart/v0.3.8
rjonczy Mar 24, 2023
566ae97
chore: update evm
MatusKysel Mar 28, 2023
6a05b32
Merge pull request #2418 from Taraxa-project/update-evm
MatusKysel Mar 28, 2023
ec6516a
do not use @channel in slack notifications
rjonczy Mar 29, 2023
45e0ad4
rename files
rjonczy Mar 29, 2023
95c2cc7
move bootnode loadbalancer service to one file
rjonczy Mar 29, 2023
1c9f233
move nodePort and loadBalancer for rpc node into 1 files
rjonczy Mar 29, 2023
711d5e8
port-check cm not used
rjonczy Mar 29, 2023
b1be529
rename transaction generation file name manifests
rjonczy Mar 29, 2023
23d07ed
added configmap suffix
rjonczy Mar 29, 2023
53cbc90
rename configmaps
rjonczy Mar 29, 2023
2b5cac1
fix with right chain-in values in comment
rjonczy Mar 29, 2023
03adff1
added consensusLight node
rjonczy Mar 29, 2023
4000279
fix consensusnodeLight statefeulset
rjonczy Mar 29, 2023
7a7e8ca
update changelog
rjonczy Mar 30, 2023
bbc82cb
rename configmap for light node
rjonczy Mar 30, 2023
73d7d40
env vars for existing secrets
rjonczy Mar 30, 2023
3583b14
add default keys for consensusLight node
rjonczy Mar 30, 2023
809ba74
Merge pull request #2421 from Taraxa-project/chart/v0.3.9
rjonczy Apr 1, 2023
455347e
Merge branch 'develop' into master-merge
MatusKysel Apr 5, 2023
fee3edc
Merge pull request #2434 from Taraxa-project/master-merge
JakubFornadel Apr 5, 2023
bb3017e
chore: minor improvements + fixes
JakubFornadel Apr 5, 2023
656b5a3
Merge branch 'develop' into fix-peer-replacement
MatusKysel Apr 6, 2023
89cebc4
fix: save own votes and gossip them in case network get stalled
JakubFornadel Apr 6, 2023
6570426
Merge pull request #2394 from Taraxa-project/fix-peer-replacement
MatusKysel Apr 7, 2023
74944cd
use rebroadcast flag in onNewPbftVote method
JakubFornadel Apr 7, 2023
10dae0b
Merge pull request #2436 from Taraxa-project/exponential_backoff
JakubFornadel Apr 10, 2023
e372a56
chore: adjust mac building compilation
JakubFornadel Apr 10, 2023
aa55889
Merge pull request #2439 from Taraxa-project/update_mac_build_doc
JakubFornadel Apr 10, 2023
e4cd97c
chore: correct check for duplicate reward votes
MatusKysel Apr 12, 2023
7c599ad
chore: fix logs
MatusKysel Apr 12, 2023
1bf6dea
fix: add revert reason to execution error
kstdl Apr 6, 2023
08132e6
Merge pull request #2437 from Taraxa-project/add_revert_reason
kstdl Apr 12, 2023
1419eb2
Merge branch 'develop' into pbft-validation
MatusKysel Apr 12, 2023
3762f8a
fix: network_test.transfer_lot_of_blocks
kstdl Apr 12, 2023
e6d28fd
Merge pull request #2447 from Taraxa-project/fix_network_test
JakubFornadel Apr 12, 2023
f0b8d65
chore: change name of the function
MatusKysel Apr 13, 2023
c8ded4e
Merge branch 'develop' into pbft-validation
MatusKysel Apr 13, 2023
903ec6d
fix: gas estimations for transactions with internal calls
kstdl Apr 11, 2023
396bc71
Merge pull request #2441 from Taraxa-project/fix_gas_estimation
kstdl Apr 13, 2023
c9527c0
Merge pull request #2446 from Taraxa-project/pbft-validation
MatusKysel Apr 13, 2023
8d85640
feat: implement db migrations
kstdl Apr 4, 2023
377bf9a
feat: add TransactionHashes migration
kstdl Apr 4, 2023
1a0b7d8
chore: resolve PR discussions
kstdl Apr 13, 2023
1b99150
fix: add batch to migration base class
kstdl Apr 13, 2023
bb4fd3a
fix: remove conan bincrafters repo and add jsonrpccpp with external_p…
kstdl Apr 17, 2023
6d40892
Merge pull request #2453 from Taraxa-project/fix_build
MatusKysel Apr 17, 2023
480b10d
chore: remove prove() code that did nothing
MatusKysel Apr 14, 2023
bb8a16e
chore: optimize copies on state prune
MatusKysel Apr 14, 2023
ffd22a1
chore: remove old structs
MatusKysel Apr 14, 2023
f180a71
chore: remove old cmake files
MatusKysel Apr 17, 2023
645d7e4
Merge pull request #2431 from Taraxa-project/migrations
kstdl Apr 17, 2023
b58eb48
Merge pull request #2449 from Taraxa-project/remove-old-code
MatusKysel Apr 17, 2023
e295ed3
chore: prune state_db manually
mfrankovi Apr 17, 2023
826688e
Merge pull request #2452 from Taraxa-project/prune_on_restart
github-merge-queue[bot] Apr 18, 2023
bda00c5
feat: change how we process db versions changes
kstdl Apr 18, 2023
3a985ec
fix: update db version only if rebuild_db or all migrations was applied
kstdl Apr 18, 2023
8cf4149
Merge pull request #2455 from Taraxa-project/db_versions
github-merge-queue[bot] Apr 18, 2023
f0a8f9f
do not regenerate genesis
rjonczy Apr 19, 2023
1feb182
Merge pull request #2456 from Taraxa-project/fix/do-not-regenerate-ge…
rjonczy Apr 19, 2023
e78e519
chore: check state root on syncing
mfrankovi Apr 20, 2023
9b17562
fix: use of all passed gas on reverts. add check to revert_reason test
kstdl Apr 21, 2023
34f8408
Merge pull request #2457 from Taraxa-project/sync_state_root_check
mfrankovi Apr 21, 2023
9bfa7f2
Merge branch 'develop' into fix_reverts_gas_used
kstdl Apr 21, 2023
f08494b
Merge pull request #2458 from Taraxa-project/fix_reverts_gas_used
kstdl Apr 21, 2023
d557974
fix: setting reward votes period
mfrankovi Apr 24, 2023
37166cc
Merge pull request #2459 from Taraxa-project/rew_votes_init
mfrankovi Apr 25, 2023
011f27e
empty commit to trigger ci
rjonczy Apr 27, 2023
0f6abd5
feat: implement trace_replayTransaction
MatusKysel Apr 27, 2023
c7ecdb9
feat: add support for tracking blocks
MatusKysel Apr 28, 2023
72e4756
chore: add check for block 0
MatusKysel May 2, 2023
d92796a
chore: simplify code
MatusKysel May 2, 2023
1ec921d
chore: update evm
MatusKysel May 3, 2023
63e07e3
Merge pull request #2462 from Taraxa-project/improve-tracing
MatusKysel May 3, 2023
db9c16c
chore: improve prune
mfrankovi May 3, 2023
38821db
Merge pull request #2465 from Taraxa-project/prune_replace_column
mfrankovi May 4, 2023
6728c0c
feat: parallel execution of state pruing
MatusKysel May 5, 2023
2959dcb
chore: update evm repo
MatusKysel May 11, 2023
ade5e8f
Merge pull request #2468 from Taraxa-project/parallel-pruning
MatusKysel May 11, 2023
985f7dc
refactor: rewards stats passing
kstdl Apr 28, 2023
363dc8e
refector: move process rewards stats functionality to separate class
kstdl May 5, 2023
184a7a2
feat: add option to change rewards distribution frequency with hardfork
kstdl May 9, 2023
a2bfdee
feat: clean LOG.old* files on db start
MatusKysel May 12, 2023
21ef2c7
Merge pull request #2463 from Taraxa-project/rewards_stats
kstdl May 12, 2023
d964baf
chore: increase timers for more stable test runs
MatusKysel May 12, 2023
4bf032b
chore: rework how Host is destroyed
MatusKysel May 15, 2023
02765ac
chore: transaction pool overflow improvements
mfrankovi May 10, 2023
45ae577
Merge pull request #2473 from Taraxa-project/trx_overflow_improvement
mfrankovi May 15, 2023
3966cf3
Merge branch 'develop' into stabilize-test
MatusKysel May 15, 2023
dbc828b
Merge pull request #2476 from Taraxa-project/stabilize-test
MatusKysel May 15, 2023
09a5da1
chore: improve sync-gossip transition
mfrankovi Apr 12, 2023
e6133da
Merge pull request #2448 from Taraxa-project/sync_gossip_transition
mfrankovi May 16, 2023
0097aea
Merge branch 'develop' into cleaing-old-files
MatusKysel May 16, 2023
ef9eb47
Merge pull request #2475 from Taraxa-project/cleaing-old-files
MatusKysel May 16, 2023
73e281b
improvement to build process
rjonczy May 16, 2023
2247c91
fix to docker tags
rjonczy May 16, 2023
dfbb266
couple fixes
rjonczy May 16, 2023
e94057c
changed based image of builder
rjonczy May 16, 2023
057374c
Merge pull request #2479 from Taraxa-project/builder/improvements-to-…
rjonczy May 17, 2023
b9dccdd
build multiarch builder
rjonczy May 17, 2023
2a28301
fix
rjonczy May 17, 2023
1343fea
fix
rjonczy May 17, 2023
d3b57e6
fix
rjonczy May 17, 2023
e78d548
fix ident
rjonczy May 17, 2023
686f8e9
fix
rjonczy May 17, 2023
9691ab0
f
rjonczy May 17, 2023
7fd2240
debug
rjonczy May 17, 2023
f33c8b2
added builder
rjonczy May 17, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion libraries/cli/include/cli/config.hpp
Original file line number Diff line number Diff line change
@@ -38,7 +38,6 @@ class Config {
static constexpr const char* REBUILD_DB = "rebuild-db";
static constexpr const char* REBUILD_DB_PERIOD = "rebuild-db-period";
static constexpr const char* REVERT_TO_PERIOD = "revert-to-period";
static constexpr const char* REBUILD_DB_COLUMNS = "rebuild-db-columns";
static constexpr const char* LIGHT = "light";
static constexpr const char* HELP = "help";
static constexpr const char* VERSION = "version";
4 changes: 0 additions & 4 deletions libraries/cli/src/config.cpp
Original file line number Diff line number Diff line change
@@ -38,7 +38,6 @@ Config::Config(int argc, const char* argv[]) {
bool destroy_db = false;
bool rebuild_network = false;
bool rebuild_db = false;
bool rebuild_db_columns = false;
bool light_node = false;
bool version = false;
uint64_t rebuild_db_period = 0;
@@ -81,8 +80,6 @@ Config::Config(int argc, const char* argv[]) {
"rebuilding all the other "
"database tables - this could take a long "
"time");
node_command_options.add_options()(REBUILD_DB_COLUMNS, bpo::bool_switch(&rebuild_db_columns),
"Removes old DB columns ");
node_command_options.add_options()(REBUILD_DB_PERIOD, bpo::value<uint64_t>(&rebuild_db_period),
"Use with rebuild-db - Rebuild db up "
"to a specified period");
@@ -264,7 +261,6 @@ Config::Config(int argc, const char* argv[]) {
}
node_config_.db_config.db_revert_to_period = revert_to_period;
node_config_.db_config.rebuild_db = rebuild_db;
node_config_.db_config.rebuild_db_columns = rebuild_db_columns;
node_config_.db_config.rebuild_db_period = rebuild_db_period;

node_config_.enable_test_rpc = enable_test_rpc;
1 change: 0 additions & 1 deletion libraries/config/include/config/config.hpp
Original file line number Diff line number Diff line change
@@ -16,7 +16,6 @@ struct DBConfig {
PbftPeriod db_revert_to_period = 0;
bool rebuild_db = false;
PbftPeriod rebuild_db_period = 0;
bool rebuild_db_columns = false;
};

void dec_json(Json::Value const &json, DBConfig &db_config);
7 changes: 4 additions & 3 deletions libraries/core_libs/node/src/node.cpp
Original file line number Diff line number Diff line change
@@ -26,6 +26,7 @@
#include "network/rpc/jsonrpc_http_processor.hpp"
#include "network/rpc/jsonrpc_ws_server.hpp"
#include "pbft/pbft_manager.hpp"
#include "storage/migration/migration_manager.hpp"
#include "transaction/gas_pricer.hpp"
#include "transaction/transaction_manager.hpp"

@@ -62,11 +63,9 @@ void FullNode::init() {
conf_.db_config.db_max_open_files, conf_.db_config.db_max_snapshots,
conf_.db_config.db_revert_to_period, node_addr, true);
}

db_ = std::make_shared<DbStorage>(conf_.db_path, conf_.db_config.db_snapshot_each_n_pbft_block,
conf_.db_config.db_max_open_files, conf_.db_config.db_max_snapshots,
conf_.db_config.db_revert_to_period, node_addr, false,
conf_.db_config.rebuild_db_columns);
conf_.db_config.db_revert_to_period, node_addr, false);

if (db_->hasMinorVersionChanged()) {
LOG(log_si_) << "Minor DB version has changed. Rebuilding Db";
@@ -82,6 +81,8 @@ void FullNode::init() {
if (db_->getDagBlocksCount() == 0) {
db_->setGenesisHash(conf_.genesis.genesisHash());
}

storage::migration::Manager(db_).applyAll();
}
LOG(log_nf_) << "DB initialized ...";

Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
#pragma once
#include "storage/storage.hpp"

namespace taraxa::storage::migration {
class Base {
public:
Base(std::shared_ptr<DbStorage> db) : db_(std::move(db)), batch_(db_->createWriteBatch()) {}
virtual ~Base() = default;
virtual std::string id() = 0;
// We need to specify version here, so in case of major version change(db reindex) we won't apply unneeded migrations
virtual uint32_t dbVersion() = 0;

bool isApplied() { return db_->lookup_int<bool>(id(), DB::Columns::migrations).has_value(); }
void apply() {
if (db_->getMajorVersion() != dbVersion()) {
return;
}
migrate();
setApplied();
db_->commitWriteBatch(batch_);
}

protected:
// Method with custom logic. All db changes should be made using `batch_`
virtual void migrate() = 0;

void setApplied() { db_->insert(batch_, DB::Columns::migrations, id(), true); }

std::shared_ptr<DbStorage> db_;
DB::Batch batch_;
};
} // namespace taraxa::storage::migration
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
#pragma once
#include "storage/migration/migration_base.hpp"

namespace taraxa::storage::migration {
class Manager {
public:
explicit Manager(std::shared_ptr<DbStorage> db, const addr_t& node_addr = {});
template <typename T>
void registerMigration() {
migrations_.push_back(std::make_shared<T>(db_));
}
void applyAll();

private:
std::shared_ptr<DbStorage> db_;
std::vector<std::shared_ptr<migration::Base>> migrations_;
LOG_OBJECTS_DEFINE
};
} // namespace taraxa::storage::migration
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
#pragma once
#include <libdevcore/Common.h>

#include "final_chain/final_chain.hpp"
#include "storage/migration/migration_base.hpp"
#include "transaction/transaction.hpp"

namespace taraxa::storage::migration {
class TransactionHashes : public migration::Base {
public:
TransactionHashes(std::shared_ptr<DbStorage> db);
std::string id() override;
uint32_t dbVersion() override;
void migrate() override;
};
} // namespace taraxa::storage::migration
8 changes: 7 additions & 1 deletion libraries/core_libs/storage/include/storage/storage.hpp
Original file line number Diff line number Diff line change
@@ -90,6 +90,8 @@ class DbStorage : public std::enable_shared_from_this<DbStorage> {

// do not change/move
COLUMN(default_column);
// migrations
COLUMN(migrations);
// Contains full data for an executed PBFT block including PBFT block, cert votes, dag blocks and transactions
COLUMN_W_COMP(period_data, getIntComparator<PbftPeriod>());
COLUMN(genesis);
@@ -141,6 +143,7 @@ class DbStorage : public std::enable_shared_from_this<DbStorage> {
const uint32_t kDbSnapshotsMaxCount = 0;
std::set<PbftPeriod> snapshots_;

uint32_t kMajorVersion_;
bool minor_version_changed_ = false;

auto handle(Column const& col) const { return handles_[col.ordinal_]; }
@@ -150,7 +153,7 @@ class DbStorage : public std::enable_shared_from_this<DbStorage> {
public:
explicit DbStorage(fs::path const& base_path, uint32_t db_snapshot_each_n_pbft_block = 0, uint32_t max_open_files = 0,
uint32_t db_max_snapshots = 0, PbftPeriod db_revert_to_period = 0, addr_t node_addr = addr_t(),
bool rebuild = false, bool rebuild_columns = false);
bool rebuild = false);
~DbStorage();

DbStorage(const DbStorage&) = delete;
@@ -173,6 +176,9 @@ class DbStorage : public std::enable_shared_from_this<DbStorage> {
void disableSnapshots();
void enableSnapshots();

uint32_t getMajorVersion() const;
std::unique_ptr<rocksdb::Iterator> getColumnIterator(const Column& c);

// Genesis
void setGenesisHash(const h256& genesis_hash);
std::optional<h256> getGenesisHash();
20 changes: 20 additions & 0 deletions libraries/core_libs/storage/src/migration/migration_manager.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#include "storage/migration/migration_manager.hpp"

#include "storage/migration/transaction_hashes.hpp"

namespace taraxa::storage::migration {
Manager::Manager(std::shared_ptr<DbStorage> db, const addr_t& node_addr) : db_(db) {
LOG_OBJECTS_CREATE("MIGRATIONS");
registerMigration<migration::TransactionHashes>();
}

void Manager::applyAll() {
for (const auto& m : migrations_) {
if (!m->isApplied()) {
LOG(log_nf_) << "Applying migration " << m->id();
m->apply();
LOG(log_nf_) << "Migration applied " << m->id();
}
}
}
} // namespace taraxa::storage::migration
37 changes: 37 additions & 0 deletions libraries/core_libs/storage/src/migration/transaction_hashes.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
#include "storage/migration/transaction_hashes.hpp"

namespace taraxa::storage::migration {
struct OldTransactionsHashes {
std::string serialized_;
size_t count_;

explicit OldTransactionsHashes(std::string serialized)
: serialized_(std::move(serialized)), count_(serialized_.size() / dev::h256::size) {}
dev::h256 get(size_t i) const {
return dev::h256(reinterpret_cast<const uint8_t*>(serialized_.data() + i * dev::h256::size),
dev::h256::ConstructFromPointer);
}
size_t count() const { return count_; }
};

TransactionHashes::TransactionHashes(std::shared_ptr<DbStorage> db) : migration::Base(db) {}

std::string TransactionHashes::id() { return "TransactionHashes"; }

uint32_t TransactionHashes::dbVersion() { return 1; }

void TransactionHashes::migrate() {
auto it = db_->getColumnIterator(DB::Columns::final_chain_transaction_hashes_by_blk_number);

// Get and save data in new format for all blocks
for (it->SeekToFirst(); it->Valid(); it->Next()) {
::taraxa::TransactionHashes new_data;
auto old_data = std::make_unique<OldTransactionsHashes>(it->value().ToString());
new_data.reserve(old_data->count());
for (size_t i = 0; i < new_data.capacity(); ++i) {
new_data.emplace_back(old_data->get(i));
}
db_->insert(batch_, DB::Columns::final_chain_transaction_hashes_by_blk_number, it->key(), dev::rlp(new_data));
}
}
} // namespace taraxa::storage::migration
25 changes: 16 additions & 9 deletions libraries/core_libs/storage/src/storage.cpp
Original file line number Diff line number Diff line change
@@ -20,8 +20,7 @@ static constexpr uint16_t DAG_BLOCKS_POS_IN_PERIOD_DATA = 2;
static constexpr uint16_t TRANSACTIONS_POS_IN_PERIOD_DATA = 3;

DbStorage::DbStorage(fs::path const& path, uint32_t db_snapshot_each_n_pbft_block, uint32_t max_open_files,
uint32_t db_max_snapshots, PbftPeriod db_revert_to_period, addr_t node_addr, bool rebuild,
bool rebuild_columns)
uint32_t db_max_snapshots, PbftPeriod db_revert_to_period, addr_t node_addr, bool rebuild)
: path_(path),
handles_(Columns::all.size()),
kDbSnapshotsEachNblock(db_snapshot_each_n_pbft_block),
@@ -61,9 +60,7 @@ DbStorage::DbStorage(fs::path const& path, uint32_t db_snapshot_each_n_pbft_bloc
});
LOG_OBJECTS_CREATE("DBS");

if (rebuild_columns) {
rebuildColumns(options);
}
rebuildColumns(options);

// Iterate over the db folders and populate snapshot set
loadSnapshots();
@@ -80,15 +77,15 @@ DbStorage::DbStorage(fs::path const& path, uint32_t db_snapshot_each_n_pbft_bloc
dag_blocks_count_.store(getStatusField(StatusDbField::DagBlkCount));
dag_edge_count_.store(getStatusField(StatusDbField::DagEdgeCount));

uint32_t major_version = getStatusField(StatusDbField::DbMajorVersion);
kMajorVersion_ = getStatusField(StatusDbField::DbMajorVersion);
uint32_t minor_version = getStatusField(StatusDbField::DbMinorVersion);
if (major_version == 0 && minor_version == 0) {
if (kMajorVersion_ == 0 && minor_version == 0) {
saveStatusField(StatusDbField::DbMajorVersion, TARAXA_DB_MAJOR_VERSION);
saveStatusField(StatusDbField::DbMinorVersion, TARAXA_DB_MINOR_VERSION);
} else {
if (major_version != TARAXA_DB_MAJOR_VERSION) {
if (kMajorVersion_ != TARAXA_DB_MAJOR_VERSION) {
throw DbException(string("Database version mismatch. Version on disk ") +
getFormattedVersion({major_version, minor_version}) +
getFormattedVersion({kMajorVersion_, minor_version}) +
" Node version:" + getFormattedVersion({TARAXA_DB_MAJOR_VERSION, TARAXA_DB_MINOR_VERSION}));
} else if (minor_version != TARAXA_DB_MINOR_VERSION) {
minor_version_changed_ = true;
@@ -100,6 +97,10 @@ void DbStorage::rebuildColumns(const rocksdb::Options& options) {
std::unique_ptr<rocksdb::DB> db;
std::vector<std::string> column_families;
rocksdb::DB::ListColumnFamilies(options, db_path_.string(), &column_families);
if (column_families.empty()) {
LOG(log_wr_) << "DB isn't initialized in rebuildColumns. Skip it";
return;
}

std::vector<rocksdb::ColumnFamilyDescriptor> descriptors;
descriptors.reserve(column_families.size());
@@ -262,6 +263,12 @@ DbStorage::~DbStorage() {
checkStatus(db_->Close());
}

uint32_t DbStorage::getMajorVersion() const { return kMajorVersion_; }

std::unique_ptr<rocksdb::Iterator> DbStorage::getColumnIterator(const Column& c) {
return std::unique_ptr<rocksdb::Iterator>(db_->NewIterator(read_options_, handle(c)));
}

void DbStorage::checkStatus(rocksdb::Status const& status) {
if (status.ok()) return;
throw DbException(string("Db error. Status code: ") + std::to_string(status.code()) +