-
-
Notifications
You must be signed in to change notification settings - Fork 93
This issue was moved to a discussion.
You can continue the conversation there. Go to discussion →
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
Query UTXO by Address. #199
Comments
Hey, the recommended method now is to build / use a chain-index for resolving output references associated to addresses. Some 3rd-party APIs such as Blockfrost or Koios provides such functionality. If you want to remain in control of your infrastructure, I can recommended tools such as Kupo or Oura for keeping track of the chain on your behalf. |
I could Use Oura that's for sure since I already use it. Thanks for the heads up. Just help me understand. How does requiring you to run more and more infrastructure to do simple things like querying an address' UTXOs help with decentralization? I feel like I'm propagating the same data twice, one with cardano-node and one with whatever solution like Oura for example, seems a little repetitive no? Do you know, will cardano-cli still support querying UTXO's by address? Thank you. |
I don't see the connection between decentralization and running different software components. Having many small components, in the spirit of the UNIX philosophy, arguably makes it easier for people to build solutions using just what they need for their projects. Also, querying UTxO by address is unfortunately not "simple". Behind the scene, UTxO are stored as an index of output references to outputs. Thus, looking up UTxOs by output references can be achieved in logarithmic (in the size of the UTxO set) complexity, but, looking up UTxO by address requires a linear scan of the set which, in the best case, is of linear complexity. As the UTxO grows and reaches millions of entries, a single lookup becomes a quite expensive operation. So long as the UTxO was held in plain "hot" memory it didn't matter too much. But with the recent updates, the UTxO is now stored on disk, in multiple shards. Thus, looking up a single entry by address requires many filesystem access and is really heavy on the CPU. It doesn't scale. Arguably, you could say that the node could maintain a reverse index itself, and makes it easier. But the node is a semi-formally verified and critical piece of software, so one wants to minimise the inherent complexity of that software as much as possible. This offloading the tasks to external components. The cardano-cli, like Ogmios, still supports querying UTxO by addresses so long as the node supports it. Yet, it is subjects to the same limitations and will eventually be removed all the same. |
Ahh first off thank you for the explanation all of this makes a lot more sense now really especially the bit on how UTXOs are actually stored and the underlying changes to the node storage especially the sharding part. I guess since I'm already using Kupo and Oura to do other tasks it's not much of a hassle to handle one extra task. Thank you again. |
This issue was moved to a discussion.
You can continue the conversation there. Go to discussion →
Hi,
Im currently using the local state query to get address current UTXOs with cardano-node 1.34.1 without any issues.
However I read that this is supposed to be deprecated? If this is correct what is the recommended method to aquire address current UTXOs?
Thanks.
The text was updated successfully, but these errors were encountered: