Bitcoin Stack Exchange is a question and answer site for Bitcoin crypto-currency enthusiasts. It only takes a minute to sign up.
Sign up to join this communityAnybody can ask a question
Anybody can answer
The best answers are voted up and rise to the top
This is a bit long - please bare with me, i want to understand exactly what a full node and SPV does in verifying transactions and some other things:
- Transaction start, A wants to send B, 1 BTC of value.
- Lets assume A's wallet controls 2 UTXOs which reference 1.1 of BTC of value in total (0.5 BTC & 0.6 BTC). At this point in time, pre any transaction from A to B, I assume full nodes will have recorded that these UTXOs are indeed unspent so far (?)
- A goes ahead and creates this transaction: the inputs to the transaction will refer to the transaction which contains the first 0.5 UTXO as an output with a reference number and a signature (to indeed unlock and spend this UTXO which has been locked to A's public key hash), same for the second UTXO we want to spend (?) The outputs are just one to B (ignoring the 0.1 change back to A), which has the satoshi value being moved, 100m Sats in this case and also a script lock to B's public key hash (?)
- The transaction is now sent on to the network.
- Full nodes verify: the signature from A does indeed unlock the outputs he wants to spend. These outputs have not been double spent (i.e. they still exist in the set of UTXOs). Inputs >= Outputs (lets ignore tx fees) and some other cursory checks (i.e. size <=21m BTC etc) (?)
- Once verified by a full Node (and accepted) they propagate the tx onwards to others they are connected to. They update their state of all UTXOs (removing those which are 'spent' and updating to the new ones created by this tx, which remain unspent).
- The tx sits in a pool waiting to be picked up by a miner. Even if this tx in particular is not picked up by any miners for the next block it remains considered 'spent' (?)
Lets say it gets mined in block 1000, current block height is 1005.
Now moving to SPVs:
- B wants to verify that the tx from A->B has indeed gone through.
- B runs an SPV node and queries a full node to check this. The full node (for his address) returns him a merkle path and the blockheaders from 1000 to 1005 to verify this.
- B, given the tx id, can indeed verify that given the Merkle Path & tx id he can recreate the Merkle Root (so the tx is in the block 1000) (?)
- Are the remaining block headers just used for him to verify that given he has verified the Merkle Root in the block header of 1000, he can now hash that, to verify that the next block header (1001) does indeed contain the previous block hash (i.e. that of 1000) (?) to make sure that the block has been built upon and now has 5 confirmations?
You can get bonuses upto $100 FREE BONUS when you:
π° Install these recommended apps:
π² SocialGood - 100% Crypto Back on Everyday Shopping
π² xPortal - The DeFi For The Next Billion
π² CryptoTab Browser - Lightweight, fast, and ready to mine!
π° Register on these recommended exchanges:
π‘ Binanceπ‘ Bitfinexπ‘ Bitmartπ‘ Bittrexπ‘ Bitget
π‘ CoinExπ‘ Crypto.comπ‘ Gate.ioπ‘ Huobiπ‘ Kucoin.
Comments