Difference between revisions of "Peer-to-Peer Network Architecture"
AlexMackay (talk | contribs) |
|||
(15 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
− | Peer-to-Peer computing or networking is a distributed application network architecture that | + | Peer-to-Peer computing or networking is a distributed application network architecture that shares resources amongst the participants. Participants are called nodes and are said to form a Peer-to-Peer network [1]. A distributed network architecture is classified as a "Pure" Peer-to-Peer if the removal of any single, arbitrarily chosen, node will not result in the loss of network service. |
− | ==Bitcoin | + | ==The Bitcoin Peer-to-Peer Network== |
− | Formally, Bitcoin is a | + | Formally, the Bitcoin network is a Pure Peer-to-Peer network built on top of the internet. In the early days of Bitcoin the network had a flat topological structure, in which users were capable of running full nodes that could perform all of Bitcoin's main functions: transaction creation, transaction validation and [[Mining |mining]] (see [https://www.metzdowd.com/pipermail/cryptography/2009-January/014994.html bitcoinv0.1]). However, as the network has grown, the requirements needed to perform each function on the network have evolved creating a necessity for nodes to specialize. Currently, the 3 main functions of the Bitcoin system are, in general, performed by separate actors within the ecosystem. Transaction creation is done by [[Simplified Payment Verification|SPV]] wallets. Transaction validation is done by the Bitcoin SV node client software and mining is a separate function performed using purpose built mining software. |
==Peer-to-Peer Architecture and the Bitcoin Scalability Dispute== | ==Peer-to-Peer Architecture and the Bitcoin Scalability Dispute== | ||
− | Peer-to-peer is a term often misused and misunderstood, partly due the philosophical significance of ''decentralization'' which is seen as a key feature of blockchain technology. It has also been at the heart of disputes within the Bitcoin community that have lead to contentious | + | Peer-to-peer is a term often misused and misunderstood, partly due the philosophical significance of ''decentralization'' which is seen as a key feature of "blockchain technology". It has also been at the heart of disputes within the Bitcoin community that have lead to contentious ledger duplications that have resulted in the creation of competing [[blockchain|blockchains]] on two occasions as well as generally delayed the development of the technology. |
− | + | The role of transaction validation and mining cannot be dominated by a single entity as the network would cease to provide any cryptographic or game theoretic advantages over existing centralized digital money systems. It is the firm belief of the Bitcoin SV community that scalability can be achieved through specialization whilst maintaining strong security and distribution of the network in a leaderless manner. | |
− | |||
− | |||
− | |||
− | |||
− | |||
==References== | ==References== | ||
− | Rüdiger Schollmeier, A Definition of Peer-to-Peer Networking for the Classification of Peer-to-Peer Architectures and Applications, Proceedings of the First International Conference on Peer-to-Peer Computing, IEEE (2002). | + | 1. Rüdiger Schollmeier, [https://www.researchgate.net/publication/3940901_A_Definition_of_Peer-to-Peer_Networking_for_the_Classification_of_Peer-to-Peer_Architectures_and_Applications A Definition of Peer-to-Peer Networking for the Classification of Peer-to-Peer Architectures and Applications], Proceedings of the First International Conference on Peer-to-Peer Computing, IEEE (2002). |
Latest revision as of 01:47, 11 January 2022
Peer-to-Peer computing or networking is a distributed application network architecture that shares resources amongst the participants. Participants are called nodes and are said to form a Peer-to-Peer network [1]. A distributed network architecture is classified as a "Pure" Peer-to-Peer if the removal of any single, arbitrarily chosen, node will not result in the loss of network service.
The Bitcoin Peer-to-Peer Network
Formally, the Bitcoin network is a Pure Peer-to-Peer network built on top of the internet. In the early days of Bitcoin the network had a flat topological structure, in which users were capable of running full nodes that could perform all of Bitcoin's main functions: transaction creation, transaction validation and mining (see bitcoinv0.1). However, as the network has grown, the requirements needed to perform each function on the network have evolved creating a necessity for nodes to specialize. Currently, the 3 main functions of the Bitcoin system are, in general, performed by separate actors within the ecosystem. Transaction creation is done by SPV wallets. Transaction validation is done by the Bitcoin SV node client software and mining is a separate function performed using purpose built mining software.
Peer-to-Peer Architecture and the Bitcoin Scalability Dispute
Peer-to-peer is a term often misused and misunderstood, partly due the philosophical significance of decentralization which is seen as a key feature of "blockchain technology". It has also been at the heart of disputes within the Bitcoin community that have lead to contentious ledger duplications that have resulted in the creation of competing blockchains on two occasions as well as generally delayed the development of the technology.
The role of transaction validation and mining cannot be dominated by a single entity as the network would cease to provide any cryptographic or game theoretic advantages over existing centralized digital money systems. It is the firm belief of the Bitcoin SV community that scalability can be achieved through specialization whilst maintaining strong security and distribution of the network in a leaderless manner.
References
1. Rüdiger Schollmeier, A Definition of Peer-to-Peer Networking for the Classification of Peer-to-Peer Architectures and Applications, Proceedings of the First International Conference on Peer-to-Peer Computing, IEEE (2002).