|
Performance
Charts below present system memory and time needed to sync BTC block chain up to the given block number.
Note:
Gocoin uses (configurable) LastTrustedBlock to avoid verifying scripts from all blocks known as valid.
Referenced Bitcoin Core uses an identical mechanism (configurable with assumevalid parameter).
Both implementations come with a recent trusted block built into their code (no need to configure them explicitly).
Gocoin 1.11.0, built with Go 1.23.4
Benchmarks were run on Hetzner dedicated server
with 3.2GHz Intel i7-8700 CPU, 128GB RAM, 2x1TB SSD and 1Gbit internet connection,
running Debian 12 (bookworm).
Effect of Memory.CacheOnDisk config value on blockchain sync speed
data:image/s3,"s3://crabby-images/774ee/774ee8f3c16e35c34bac05c37cf7cde31e593535" alt=""
Possible chain sync speed with a tweaked configuration
data:image/s3,"s3://crabby-images/f3070/f307070a3d1bd98e4b7a85dc38c3badd074c710a" alt=""
Changed config values:
Memory.GCPercTrshold: 300
Memory.CacheOnDisk: false
MaxSyncCacheMB": 2500
CompressBlockDB: false
Gocoin 1.10.1, built with Go 1.18.3
Dedicated server with 3.4GHz Intel i7-6700 CPU and HDD
With comparision to Bitcoin Core 23.0:
data:image/s3,"s3://crabby-images/87f3b/87f3bb0830c9a25a41e647f5b26d0464adb86865" alt=""
Both the clients were using their default configuration.
Dedicated server with 3.6GHz Intel i7-7700 CPU and SSD
Default config:
data:image/s3,"s3://crabby-images/afc17/afc1705ad80fab6edd39465330a0da686304f9e6" alt=""
Time needed to re-build UTXO database from blocks stored on the disk: 1.2 hours
(up to block #700000)
Tweaked config:
data:image/s3,"s3://crabby-images/62227/62227b69a2aecca427ddba97a6a06ec0472e9300" alt=""
Changed config values:
Net.ListenTCP: false
Net.MaxOutCons: 20
Memory.GCPercTrshold: 300
Memory.UseGoHeap: true
Memory.CacheOnDisk: false
AllBalances.AutoLoad: false
Stat.NoCounters: true
Dedicated server with 3.4GHz Intel i7-6700 CPU and SSD
Default config:
data:image/s3,"s3://crabby-images/fe9f4/fe9f47b89273c12bf83d1b3011a88f66f0c36d19" alt=""
Time needed to re-build UTXO database from blocks stored on the disk: 1.3 hours
(up to block #700000)
Dedicated server with 3.4GHz Intel i7-4770 CPU and HDD
Default config:
data:image/s3,"s3://crabby-images/27539/275395193735d54c82249069cf5b2d769cfcb2d1" alt=""
Time needed to re-build UTXO database from blocks stored on the disk: 1.4 hours
(up to block #700000)
Tweaked config:
data:image/s3,"s3://crabby-images/bc284/bc2849f684c1691f0d3c0c089bdcd216e75aecd1" alt=""
Time needed to re-build UTXO database from blocks stored on the disk: 1.3 hours
(up to block #700000)
Changed config values:
Net.ListenTCP: false
Net.MaxOutCons: 20
Memory.GCPercTrshold: 100
Memory.UseGoHeap: true
Memory.CacheOnDisk: false
AllBalances.AutoLoad: false
Stat.NoCounters: true
Gocoin 1.10.0, built with Go 1.17.3
Dedicated server with 3.5GHz Xeon E3-1270 v3 CPU and SSD
Default config:
data:image/s3,"s3://crabby-images/f6999/f69999b281a5aa7e214166db036274d227266fa2" alt=""
Time needed to re-build UTXO database from blocks stored on the disk: 1.6 hours
(up to block #700000)
Dedicated server with two 1.7GHz Xeon E5-2650L v2 CPUs and HDD
Default config:
data:image/s3,"s3://crabby-images/e85bb/e85bb28ebc82732f24eed96e4414dc6f7e662c84" alt=""
Time needed to re-build UTXO database from blocks stored on the disk: 2.6 hours
(up to block #700000)
|