SegWit (Segregated Witness)
DEFINITION of 'SegWit (Segregated Witness)'
SegWit is the process by which the block size limit on a blockchain is increased by removing signature data from Bitcoin transactions. When certain parts of a transaction are removed, this frees up space or capacity to add more transactions to the chain.
Segregate means to separate, and Witnesses are the transaction signatures. Hence, Segregated Witness in short, means to separate transaction signatures.
The concept of SegWit was formulated by Dr. Pieter Wuille.
BREAKING DOWN 'SegWit (Segregated Witness)'
The bitcoin blockchain consists of multiple systems distributed across a peer-to-peer network. These systems are called nodes and serve as the administrators of Bitcoin transactions. All transactions made in Bitcoin are duplicated across these nodes, making it virtually impossible to hack into and corrupt a transaction.
The transaction data that is shared across the multiple nodes consists of two components – inputs and outputs. There could be one or multiple inputs and outputs involved in a transaction. The output is the public address of the recipient. The input is the public address of the sender. The sender needs the recipient’s public address in order to send funds to him or her. The majority of space in a transaction consists of a signature, a part of the input, which verifies that the sender has the required funds to make a payment. So in effect, a Bitcoin moves from inputs to outputs for each transaction transmitted. Once each of the nodes have verified the transaction as valid, the transaction is included in a block which is added to the chain or the general ledger for public access.
The problem that the Bitcoin platform is facing is that as more and more transactions are being conducted, more blocks have to be added to the chain. Blocks are generated every 10 minutes and are constrained to a maximum size of 1 megabyte (MB). Due to this constraint, only a certain number of transactions can be added to a block. The weight of the transactions, represented by the blocks, is weighing down the network and causing delays in processing and verifying transactions, in some cases, taking hours to confirm a transaction as valid. Imagine all Bitcoin transactions that have been carried out since the inception of Bitcoin in 2009 sitting on the blockchain and still piling up. Long term, the system would not be sustainable if a radical change is not made.
Dr. Pieter Wuille suggests that to solve this problem, the digital signature needs to be segregated from the transactions data. This process is known as Segregated Witness or SegWit. Digital signature accounts for 65% of the space in a given transaction. SegWit attempts to ignore the data attached to a signature by stripping off the signature from within the input and moving it to a structure towards the end of a transaction. This would increase the 1 MB limit for block sizes to a little under 4 MB. In addition to slightly increasing the capacity size of blocks, SegWit also solves the problem where a receiver could intercept and modify the sender’s transaction ID in a bid to get more coins from the sender. Since the digital signature would be detached from the input, the unscrupulous party would have no way of changing the transaction ID without also nullifying the digital signature.
As of May 2017, SegWit is yet to be put in effect. 95% of the Bitcoin community have to agree to this new process and switch to the new Bitcore Core client for at least two weeks, before SegWit can be successfully activated. So far, only an estimated 30% have signed up for it.
like
vote and follow me.. @kanggary
ok good
like
Congratulations @duapin1! You have completed some achievement on Steemit and have been rewarded with new badge(s) :
You published your First Post
You made your First Vote
You got a First Vote
You made your First Comment
Click on any badge to view your own Board of Honor on SteemitBoard.
For more information about SteemitBoard, click here
If you no longer want to receive notifications, reply to this comment with the word
STOP