The getaddressesbylabel
API spends a lot more time than the getaddressesbyaccount
API.
I generated addresses by the getnewaddress
API, then, I measured time that the getaddressesby*
API spends. It seems the algorithm of the getaddressesbylabel
API takes O(N ^ 2) time! The results of my survey are as follows.
getaddressesbylabel
bitcoind v0.17.1 on Ubuntu 16.04 (AWS EC2 t3.large)
11,001 addresses
0time sudo /usr/local/bin/bitcoin-cli -conf=/etc/bitcoin/bitcoin.conf getaddressesbylabel ""
1# (omitted)
2real 0m1.230s # 1.2s
3user 0m0.044s
4sys 0m0.048s
111,001 addresses
0time sudo /usr/local/bin/bitcoin-cli -conf=/etc/bitcoin/bitcoin.conf getaddressesbylabel ""
1# (omitted)
2real 1m37.027s # 97.0s
3user 0m0.408s
4sys 0m0.544s
211,001 addresses
0time sudo /usr/local/bin/bitcoin-cli -conf=/etc/bitcoin/bitcoin.conf getaddressesbylabel ""
1# (omitted)
2real 6m3.727s # 363.7s
3user 0m0.800s
4sys 0m0.900s
getaddressesbyaccount
bitcoind v0.16.3 on Ubuntu 16.04 (AWS EC2 t3.large)
11,001 addresses
0time sudo /usr/local/bin/bitcoin-cli -conf=/etc/bitcoin/bitcoin.conf getaddressesbyaccount ""
1# (omitted)
2real 0m0.500s # 0.5s
3user 0m0.092s
4sys 0m0.160s
111,001 addresses
0time sudo /usr/local/bin/bitcoin-cli -conf=/etc/bitcoin/bitcoin.conf getaddressesbyaccount ""
1# (omitted)
2real 0m1.361s # 1.4s
3user 0m0.168s
4sys 0m0.348s
211,001 addresses
0time sudo /usr/local/bin/bitcoin-cli -conf=/etc/bitcoin/bitcoin.conf getaddressesbyaccount ""
1# (omitted)
2real 0m2.220s # 2.2s
3user 0m0.384s
4sys 0m0.532s