-
Notifications
You must be signed in to change notification settings - Fork 86
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
Implementing blockchain.outpoint.subscribe method #104
Comments
Hmm.. I have to think about this. Just a few points:
I still have to think about this more but a potential way to do it would be the DoSey implementation ideas you suggest and just have it as a "WARNING DO NOT USE THIS ON PUBLIC SERVERS". This way it could just be data served up to a block explorer for a Fulcrum server that is not public. Or.. somesuch. I will need to continue thinking about this. Obviously if Electrum protocol 1.5 does end up being adopted widely enough, Fulcrum will have to implement this eventually anyway... |
Thanks for your insights ! About the CTOR issue: we can still use the fact that the spending transaction I don't think we need the spk argument, we should be able to retrieve the scriptPubKey by loading the funding transaction directly (this argument is only needed by personnal servers that only index some addresses on the fly). I agree with you that this is really a "quick and dirty" implementation of the method anyway. This is clearly something to use only for a private instance of Fulcrum (or small community). The main use case is a Raspberry Pi node with a personal block explorer. Having the spending transaction is quite nice to do "home made chainalysis" of its own funds :p Let me know if (and when) you plan to work on this ! I would be very happy to test a PR for you with my blockexplorer :) loading 4000 outpoints at the same time will be a good test of the performances :p ! |
Thanks for your insights and thoughts and offer to help. I definitely will ask you to test this when I implement it! I may get some free time in a few weeks to spend time on it. I am just tempted to go the "use a real index for this" route since I am a performance nazi and the fact that it could potentially be slow irks me. Compared to the size of the BTC blockchain for instance, another ~10G index isn't THAT BAD. Hmm..f the usecase is "personal use", the hit won't be too bad to do the slower lookups without a real index. And each index we add does eat into sync time performance as it's one extra disk write that needs to happen. Hmm. I'll ponder this some more. I would definitely start out by testing either approach and seeing what the real tradeoffs are before I make a final decision. I'm super undecided until then.... Right, I can see how this is more useful for LN. I definitely would initially lean on the "optional feature" in either case and if push comes to shove, BTC-specific is fine. On BCH we don't have LN (although we could technically implement it if we needed it, but tx volume is low relative to block size... as are fees... so we haven't really done so...). Hmm. I have to ponder the design and try out a few ideas. I'll let you know if/when I seriously start to work on it, for sure. |
We are on the same page :), I also think that 10G added in indexing wouldn't be so bad (in ElectrumX I would be crying because the initial syncing is so bad and crashing so often but Fulcrum sync is much more reliable...). The current Fulcrum DB is 100GB in size for BTC on my node, 10GB more is not much too me. But I also think it is better to unset this index by default at least to start, because it is quite "application specific". If you go to the index solution I think it would be possible to leverage the scripthash index much more efficiently than what is possible with ElectRS. An idea I have is the following:
Why using I think it even possible to reduce even more the size of the outpoint index: when an outpoint is spend by the very next transaction involving its scripthash, we could just .... not store anything. Then Fulcrum knows that the next That's say it is still possible that a scripthash is spammed with dust so maybe we would have to add some exceptions to this schema ? Anyway, that's quickly how I see it and I think it leverages already build indexes very efficiently. I am very glad you will work on the index path haha :) |
Hi,
I can't start without saying that your work on Fulcrum is impressive and deserves much more attention. My experience with it is so much better than ElectrumX both during sync and once synced ! It is a really impressive work !
I would like to know how hard it would be to implement
blockchain.outpoint.subscribe
method from Electrum 1.5 in Fulcrum. The main application would be to show the spending transaction of an outpoint in a block explorer. You can look at my implementation at janoside/btc-rpc-explorer#356.Implementing
blockchain.outpoint.subscribe
is straightforward in ElectRS because it builds a transaction inputs' index as explained here. Such implementation in ElectRS is available at romanz/electrs#454. If I understand well which indexes Fulcrum build, there is no such index so it won't be that easy. I don't wish to take the path of building a new index of spending transactions because building the indexes is a sufficiently painful process as it is already. That's said I would gladly try to sync and use a version of Fulcrum with such index if you implement it in the future.However, Fulcrum builds already a lot more indexes than ElectRS and I think it is possible to have a quite efficient solution without building a new one. My idea is to use the scripthash of the outpoint.
scripthash_history
index, Fulcrum will get all thetxnum
of the scripthash of the outpoint.txhash2txnum
, it can also get thetxnum
of the funding transaction. Now we use the fact that in BTC blockchain, transactions in the same block are ordered in topological order, so we know that thetxnum
of the spending transaction MUST be greater than thetxnum
of the funding transaction. I guess you want to keep Fulcrum fully compatible with BCH, I don't follow BCH protocol change but I know it used CTOR for a while, so in this case the check must be relaxed a bit: the spending transaction has atxnum
higher than the firsttxnum
of the block including the funding transaction (it is a rather small performance loss in the BTC case to keep everything compatible).scripthash_history
index that have a greatertxnum
than the funding transaction and check if they spend the outpoint of the query. If it finds the spending transaction, returns it.This is clearly suboptimal solution. It can also be a terrible DoS vector if we query the spending transaction of an outpoint with an highly used scripthash that only spend it after many other transactions involving this scripthash. I think if the outpoint is not spent we can use the
scripthash_unspent
index to detect it and avoid the almost exhaustive search among all transactions involving a scripthash. That said, I would like to try and see if it is more efficient than ElectRS which must always load full blocks to answer each query of an outpoint, it can be terribly slow if we want to look at all the spending transactions of the 4000 outpoints of a transaction like d22c53dd5a79fb6cc7a10ed6531761ae43ce1ce2ecd1ebbc5746ba82c71e6d70I would like to have your opinion on this idea, do you think it is worth to try ? Do you have a better idea ?
Thanks again for the amazing work, this is an truely amazing software !
The text was updated successfully, but these errors were encountered: