Peer exchange: Difference between revisions
Citation bot (talk | contribs) Removed parameters. | Use this bot. Report bugs. | #UCB_CommandLine |
|||
(25 intermediate revisions by 21 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|BitTorrent communications protocol}} |
|||
'''Peer exchange''' or ''' |
'''Peer exchange''' or '''PEX''' is a [[communications protocol]] that augments the [[BitTorrent (protocol)|BitTorrent]] file sharing protocol. It allows a group of users (or [[Peer-to-peer|peers]]) that are collaborating to share a given file to do so more swiftly and efficiently. |
||
In the original design of the BitTorrent file sharing protocol, peers (users) in a file sharing group (known as a "swarm") relied upon a central computer server called a [[BitTorrent tracker|tracker]] to find each other and to maintain the swarm. PEX greatly reduces the reliance of peers on a tracker by allowing each peer to directly update others in the swarm as to which peers are currently in the swarm. By reducing dependency on a centralized tracker, PEX increases the speed, efficiency, and robustness of the BitTorrent protocol. |
In the original design of the BitTorrent file sharing protocol, peers (users) in a file sharing group (known as a "swarm") relied upon a central computer server called a [[BitTorrent tracker|tracker]] to find each other and to maintain the swarm. PEX greatly reduces the reliance of peers on a tracker by allowing each peer to directly update others in the swarm as to which peers are currently in the swarm. By reducing dependency on a centralized tracker, PEX increases the speed, efficiency, and robustness of the BitTorrent protocol. |
||
==Description== |
==Description== |
||
Users wishing to obtain a copy of a file typically first download a [[Torrent file|torrent]] file that describes the file(s) to be shared, as well as the [[URL]]s of one or more central computers called [[BitTorrent tracker|trackers]] that maintain a list of peers currently sharing the file(s) described in the .torrent file. In the original BitTorrent design, peers then depended on this central tracker to find each other and maintain the swarm. Later development of [[distributed hash table]]s (DHTs) meant that partial lists of peers could be held by other computers in the swarm and the load on the central tracker computer could be reduced. PEX allows peers in a swarm to exchange information about the swarm directly without asking ([[Polling (computer science)|polling]]) a tracker computer or a DHT. By doing so, PEX leverages the knowledge of peers that a user is connected to by asking them for the addresses of peers that they are connected to. This is faster and more efficient than relying solely on one tracker and reduces the processing load on the tracker. It also |
Users wishing to obtain a copy of a file typically first download a [[Torrent file|torrent]] file that describes the file(s) to be shared, as well as the [[URL]]s of one or more central computers called [[BitTorrent tracker|trackers]] that maintain a list of peers currently sharing the file(s) described in the .torrent file. In the original BitTorrent design, peers then depended on this central tracker to find each other and maintain the swarm. Later development of [[distributed hash table]]s (DHTs) meant that partial lists of peers could be held by other computers in the swarm and the load on the central tracker computer could be reduced. PEX allows peers in a swarm to exchange information about the swarm directly without asking ([[Polling (computer science)|polling]]) a tracker computer or a DHT. By doing so, PEX leverages the knowledge of peers that a user is connected to by asking them for the addresses of peers that they are connected to. This is faster and more efficient than relying solely on one tracker and reduces the processing load on the tracker. It also keeps swarms together when the tracker is down.<ref>{{Cite web|url=http://wiki.vuze.com/enwiki/w/Peer_Exchange|title=Peer Exchange - VuzeWiki}}</ref> |
||
Peer exchange cannot be used on its own to introduce a new peer to a swarm. To make initial contact with a swarm, each peer must either connect to a tracker using a ".torrent" file, or else use a router computer called a [[bootstrap node]] to find a distributed hash table (DHT) which describes a swarm's list of peers. For most BitTorrent users, DHT and PEX will start to work automatically after the user launches a BitTorrent client and opens a .torrent file. A notable exception is "private torrents" which are not freely available; these will commonly disable DHT. |
Peer exchange cannot be used on its own to introduce a new peer to a swarm. To make initial contact with a swarm, each peer must either connect to a tracker using a ".torrent" file, or else use a router computer called a [[bootstrap node]] to find a distributed hash table (DHT) which describes a swarm's list of peers. For most BitTorrent users, DHT and PEX will start to work automatically after the user launches a BitTorrent client and opens a .torrent file. A notable exception is "private torrents" which are not freely available; these will commonly disable DHT. |
||
===Peer Exchange Conventions=== |
===Peer Exchange Conventions=== |
||
Extensions to BitTorrent such as PEX are typically implemented using one of two common extension protocols, AZMP<ref> |
Extensions to BitTorrent such as PEX are typically implemented using one of two common extension protocols, AZMP<ref>{{Cite web|url=https://wiki.vuze.com/enwiki/w/Azureus_messaging_protocol|title=Azureus messaging protocol - VuzeWiki|website=wiki.vuze.com|access-date=2019-11-20}}</ref> or LTEP.<ref>{{Cite web|url=https://www.rasterbar.com/products/libtorrent/extension_protocol.html|title=extension_protocol.rst|website=www.rasterbar.com|access-date=2019-11-20}}</ref> Both types of peer exchange send messages containing a group of peers to be added to the swarm and a group of peers to be removed. |
||
⚫ | |||
⚫ | |||
* There should be no more than 50 added peers and 50 removed peers sent in any given PEX message. |
* There should be no more than 50 added peers and 50 removed peers sent in any given PEX message. |
||
* A peer exchange message should not be sent more frequently than once a minute. |
* A peer exchange message should not be sent more frequently than once a minute. |
||
Some clients may choose to enforce these limits and drop connections from clients that ignore them.<ref> |
Some clients may choose to enforce these limits and drop connections from clients that ignore them.<ref name=":0">{{Cite web|url=https://wiki.theory.org/index.php/BitTorrentPeerExchangeConventions|title=BitTorrentPeerExchangeConventions - Theory.org Wiki|website=wiki.theory.org|access-date=2019-11-20}}</ref> |
||
===DHT=== |
===DHT=== |
||
To create a PEX protocol providing a uniformly-distributed peer selection, one could form a small DHT local to a torrent. For each desired new peer one would look up a (uniformly) random key, and use the node responsible for the key as a new peer. This is conceptually simple but would require quite some overhead.{{Citation needed|date=June 2010}} |
To create a PEX protocol providing a uniformly-distributed peer selection, one could form a small distributed hash table (DHT) local to a torrent. For each desired new peer one would look up a (uniformly) random key, and use the node responsible for the key as a new peer. This is conceptually simple but would require quite some overhead.{{Citation needed|date=June 2010}} |
||
For "trackerless" torrents, it is not clear if PEX provides any value{{Citation needed|date=June 2010}} since the mainline DHT can distribute load as necessary. Each DHT node acting as a tracker may store only a subset of the peers, but these are ''maximal'' subsets constrained only by DHT node load rather than by a single peer's view. Private torrents commonly disable the DHT, and for this case, PEX might be useful provided the peer obtains enough peers from the tracker. |
For "trackerless" torrents, it is not clear if PEX provides any value{{Citation needed|date=June 2010}} since the mainline DHT can distribute load as necessary. Each DHT node acting as a tracker may store only a subset of the peers, but these are ''maximal'' subsets constrained only by DHT node load rather than by a single peer's view. Private torrents commonly disable the DHT, and for this case, PEX might be useful provided the peer obtains enough peers from the tracker. |
||
Line 27: | Line 29: | ||
* [[Vuze]] – introduced in Azureus |
* [[Vuze]] – introduced in Azureus |
||
* [[BitComet]] – proprietary – introduced in BitComet, from version 1.19 supports BEP11,<ref>{{Cite web|last=<the8472.bep@infinite-source.de>|first=The 8472|title=bep_0011.rst_post|url=https://www.bittorrent.org/beps/bep_0011.html|access-date=2021-05-23|website=www.bittorrent.org|language=en}}</ref> compatible with MainLine<ref>{{Cite web|title=Bitcomet - Changelog|url=https://bitcomet.com/en/changelog}}</ref> |
|||
* [[BitComet]] – proprietary – introduced in BitComet |
|||
* [[BitTorrent (software)|MainLine]] – introduced in |
* [[BitTorrent (software)|MainLine]] – introduced in μTorrent |
||
==Clients supporting peer exchange== |
==Clients supporting peer exchange== |
||
{{ |
{{More citations needed section|date=July 2010}} |
||
Most BitTorrent clients use PEX to gather peers in addition to trackers and DHT. With the 3.0.5.0 release of Vuze, all major BitTorrent clients now have compatible peer exchange. |
Most BitTorrent clients use PEX to gather peers in addition to trackers and DHT. With the 3.0.5.0 release of Vuze, all major BitTorrent clients now have compatible peer exchange. |
||
Each of these clients implement some version of peer exchange: |
Each of these clients implement some version of peer exchange: |
||
*[[aria2]], μTorrent PEX support<ref>{{cite web |url=http://manpages.ubuntu.com/manpages/utopic/man1/aria2c.1.html |title=Ubuntu Manpage: Aria2c - the ultra fast download utility |access-date=2015-03-29 |url-status=dead|archive-url=https://web.archive.org/web/20150402095141/http://manpages.ubuntu.com/manpages/utopic/man1/aria2c.1.html |archive-date=2015-04-02 }}</ref> |
|||
*[[Ares Galaxy]]{{citation needed|date=September 2010}} |
|||
⚫ | *[[Vuze]], formerly Azureus, and clients based on it (The Vuze PEX is only compatible with the Transmission client. PEX with other clients has been implemented into Vuze and into Azureus from 3.0.4.3 onwards) <ref>{{cite web|title=utorrent PEX in Vuze.|publisher=Vuze Wiki website|url=http://wiki.vuze.com/enwiki/w/Version_3_Changelog#2008.03.05_-_Azureus_Vuze_3.0.5.0|access-date=2010-08-15 }}</ref> |
||
*[[aria2]], µTorrent PEX support{{citation needed|date=September 2010}} |
|||
⚫ | *[[BitComet]] supports PEX using a proprietary protocol in its older versions.<ref>{{cite web|title=PEX in BitComet.|publisher=BitComet Wiki website|url=http://wiki.bitcomet.com/Peers,_seeds,_torrent,_tracker,_DHT,_Peer_Exchange_%28PEX%29,_Magnet_Links#Peer_Exchange_.28PEX.29|access-date=2010-02-23 }}</ref> Starting with v.1.19 it also added support for the μTorrent/Mainline implementation of PEX, based on the Extension Protocol.<ref>{{cite web|title=Release notes for BitComet.|publisher=BitComet official website|url=http://www.bitcomet.com/doc/changelog.htm|access-date=2010-02-23 }}</ref> |
||
⚫ | *[[Vuze]], formerly Azureus, and clients based on it (The Vuze PEX is only compatible with the Transmission client. PEX with other clients has been implemented into Vuze and into Azureus from 3.0.4.3 onwards) <ref>{{cite web|title=utorrent PEX in Vuze.|publisher=Vuze Wiki website|url=http://wiki.vuze.com/enwiki/w/Version_3_Changelog#2008.03.05_-_Azureus_Vuze_3.0.5.0| |
||
⚫ | |||
⚫ | *[[BitComet]] supports PEX using a proprietary protocol in its older versions.<ref>{{cite web|title=PEX in BitComet.|publisher=BitComet Wiki website|url=http://wiki.bitcomet.com/Peers,_seeds,_torrent,_tracker,_DHT,_Peer_Exchange_%28PEX%29,_Magnet_Links#Peer_Exchange_.28PEX.29| |
||
⚫ | *[[BitTorrent (software)|BitTorrent]]<ref>[http://www.bittorrent.com/intl/es/help/manual/appendixa040401#Other_Settings.Peer_Exchange BitTorrent User Manual - Appendix A: The BitTorrent Interface - Miscellaneous - Torrent Properties - General - Other Settings - Peer Exchange] {{webarchive|url=https://web.archive.org/web/20140706120625/http://www.bittorrent.com/intl/es/help/manual/appendixa040401 |date=2014-07-06 }}</ref> |
||
⚫ | |||
⚫ | *[[KTorrent]] has implemented full μTorrent PEX support as of 2.1 RC1<ref>{{cite web|title=What's new in 2.1?|publisher=KTorrent official website|url=http://ktorrent.org/|archive-url=https://web.archive.org/web/20060402211409/http://ktorrent.org/|url-status=dead|archive-date=2006-04-02|access-date=2007-03-30}}</ref> |
||
⚫ | |||
⚫ | *[[libtorrent]] and clients based on it ([[Deluge (BitTorrent client)|Deluge]],<ref>{{cite web|title=Deluge 0.5.1 Beta 1 changes|url=http://forum.deluge-torrent.org/viewtopic.php?f=14&t=15#p33|access-date=2007-09-11|url-status=dead|archive-url=https://web.archive.org/web/20081225031718/http://forum.deluge-torrent.org/viewtopic.php?f=14&t=15#p33|archive-date=2008-12-25}}</ref> [[qBittorrent]],<ref>{{cite web|title=qBittorrent official website|url=http://qbittorrent.sourceforge.net/|access-date=2007-05-14 }}</ref> [[MooPolice]]<ref>{{cite web|title=MooPolice official website|url=http://www.moopolice.de/|access-date=2007-03-30 }}</ref>) compatible with [[μTorrent]] |
||
⚫ | |||
⚫ | *[[libtorrent]] and clients based on it ([[Deluge (BitTorrent client)|Deluge]],<ref>{{cite web|title=Deluge 0.5.1 Beta 1 changes|url=http://forum.deluge-torrent.org/viewtopic.php?f=14&t=15#p33| |
||
*[[Tixati]] |
*[[Tixati]] |
||
*[[ |
*[[μTorrent]]<ref>{{cite web|title=μTorrent 1.4.1 beta and 1.4.2 beta changes|url=http://forum.utorrent.com/viewtopic.php?pid=46921#p46921|access-date=2007-09-11|url-status=dead|archive-url=https://web.archive.org/web/20061125033806/http://forum.utorrent.com/viewtopic.php?pid=46921#p46921|archive-date=2006-11-25}}</ref> |
||
*[[Opera (web browser)|Opera]] 9.5, |
*[[Opera (web browser)|Opera]] 9.5, μTorrent PEX support<ref>{{cite web|title=Opera 9.5 BitTorrent support|url=http://my.opera.com/mitchman2/blog/2007/09/04/opera-9-5-alpha-and-bittorrent|access-date=2007-09-04 }}</ref> |
||
*[[qBittorrent]], |
*[[qBittorrent]], μTorrent PEX support<ref>{{cite web|title=Details of qBittorrent package|url=http://packages.debian.org/sid/qbittorrent|work=Debian Packages|access-date=2011-04-15|quote=μTorrent-compatible Peer eXchange (PeX)}}</ref> |
||
*[[rTorrent]]<ref>{{cite web|title=libTorrent 0.11.8 and rTorrent 0.7.8 Changelog|url=http://rakshasa.no/pipermail/libtorrent-devel/2007-September/001241.html| |
*[[rTorrent]]<ref>{{cite web|title=libTorrent 0.11.8 and rTorrent 0.7.8 Changelog|url=http://rakshasa.no/pipermail/libtorrent-devel/2007-September/001241.html|access-date=2007-09-11|archive-url=https://web.archive.org/web/20071103080110/http://rakshasa.no/pipermail/libtorrent-devel/2007-September/001241.html|archive-date=2007-11-03|url-status=dead}}</ref> |
||
*[[Transmission (BitTorrent)|Transmission]] (compatible with both the μTorrent and Vuze implementations)<ref>{{cite web|title=NEWS (rev 1579)|publisher=Transmission SVN|url=http://transmission.m0k.org/trac/browser/trunk/NEWS?rev=1579| |
*[[Transmission (BitTorrent)|Transmission]] (compatible with both the μTorrent and Vuze implementations)<ref>{{cite web|title=NEWS (rev 1579)|publisher=Transmission SVN|url=http://transmission.m0k.org/trac/browser/trunk/NEWS?rev=1579|access-date=2007-03-30|url-status=dead|archive-url=https://web.archive.org/web/20070824141552/http://transmission.m0k.org/trac/browser/trunk/NEWS?rev=1579|archive-date=2007-08-24}}</ref> |
||
*[[XTorrent]] being based on Transmission source code, equally fully supports the Vuze and |
*[[XTorrent]] being based on Transmission source code, equally fully supports the Vuze and μTorrent implementations as of version 1.0 (v40)<ref>[http://www.xtorrent.com/ Xtorrent P2P (for Mac OS X)]</ref> |
||
==References== |
==References== |
||
{{reflist}} |
{{reflist}}{{BitTorrent}} |
||
==External links== |
|||
*[http://wiki.vuze.com/enwiki/w/Peer_Exchange Description on the official Azureus wiki] |
|||
{{BitTorrent}} |
|||
{{DEFAULTSORT:Peer Exchange}} |
{{DEFAULTSORT:Peer Exchange}} |
||
[[Category:BitTorrent]] |
[[Category:BitTorrent]] |
||
[[da:Peer exchange]] |
|||
[[fr:Peer exchange]] |
|||
[[ru:Peer exchange]] |
|||
[[sv:Peer exchange]] |
Latest revision as of 15:46, 27 September 2023
Peer exchange or PEX is a communications protocol that augments the BitTorrent file sharing protocol. It allows a group of users (or peers) that are collaborating to share a given file to do so more swiftly and efficiently.
In the original design of the BitTorrent file sharing protocol, peers (users) in a file sharing group (known as a "swarm") relied upon a central computer server called a tracker to find each other and to maintain the swarm. PEX greatly reduces the reliance of peers on a tracker by allowing each peer to directly update others in the swarm as to which peers are currently in the swarm. By reducing dependency on a centralized tracker, PEX increases the speed, efficiency, and robustness of the BitTorrent protocol.
Description
[edit]Users wishing to obtain a copy of a file typically first download a torrent file that describes the file(s) to be shared, as well as the URLs of one or more central computers called trackers that maintain a list of peers currently sharing the file(s) described in the .torrent file. In the original BitTorrent design, peers then depended on this central tracker to find each other and maintain the swarm. Later development of distributed hash tables (DHTs) meant that partial lists of peers could be held by other computers in the swarm and the load on the central tracker computer could be reduced. PEX allows peers in a swarm to exchange information about the swarm directly without asking (polling) a tracker computer or a DHT. By doing so, PEX leverages the knowledge of peers that a user is connected to by asking them for the addresses of peers that they are connected to. This is faster and more efficient than relying solely on one tracker and reduces the processing load on the tracker. It also keeps swarms together when the tracker is down.[1]
Peer exchange cannot be used on its own to introduce a new peer to a swarm. To make initial contact with a swarm, each peer must either connect to a tracker using a ".torrent" file, or else use a router computer called a bootstrap node to find a distributed hash table (DHT) which describes a swarm's list of peers. For most BitTorrent users, DHT and PEX will start to work automatically after the user launches a BitTorrent client and opens a .torrent file. A notable exception is "private torrents" which are not freely available; these will commonly disable DHT.
Peer Exchange Conventions
[edit]Extensions to BitTorrent such as PEX are typically implemented using one of two common extension protocols, AZMP[2] or LTEP.[3] Both types of peer exchange send messages containing a group of peers to be added to the swarm and a group of peers to be removed.
It was agreed between the Azureus and μTorrent developers that any clients which implement either of the mechanisms above try to obey the following limits when sending PEX messages:[4]
- There should be no more than 50 added peers and 50 removed peers sent in any given PEX message.
- A peer exchange message should not be sent more frequently than once a minute.
Some clients may choose to enforce these limits and drop connections from clients that ignore them.[4]
DHT
[edit]To create a PEX protocol providing a uniformly-distributed peer selection, one could form a small distributed hash table (DHT) local to a torrent. For each desired new peer one would look up a (uniformly) random key, and use the node responsible for the key as a new peer. This is conceptually simple but would require quite some overhead.[citation needed]
For "trackerless" torrents, it is not clear if PEX provides any value[citation needed] since the mainline DHT can distribute load as necessary. Each DHT node acting as a tracker may store only a subset of the peers, but these are maximal subsets constrained only by DHT node load rather than by a single peer's view. Private torrents commonly disable the DHT, and for this case, PEX might be useful provided the peer obtains enough peers from the tracker.
Versions
[edit]There are three incompatible PEX implementations (making distinct "networks" in swarm)[citation needed]
- Vuze – introduced in Azureus
- BitComet – proprietary – introduced in BitComet, from version 1.19 supports BEP11,[5] compatible with MainLine[6]
- MainLine – introduced in μTorrent
Clients supporting peer exchange
[edit]This section needs additional citations for verification. (July 2010) |
Most BitTorrent clients use PEX to gather peers in addition to trackers and DHT. With the 3.0.5.0 release of Vuze, all major BitTorrent clients now have compatible peer exchange.
Each of these clients implement some version of peer exchange:
- aria2, μTorrent PEX support[7]
- Vuze, formerly Azureus, and clients based on it (The Vuze PEX is only compatible with the Transmission client. PEX with other clients has been implemented into Vuze and into Azureus from 3.0.4.3 onwards) [8]
- BitComet supports PEX using a proprietary protocol in its older versions.[9] Starting with v.1.19 it also added support for the μTorrent/Mainline implementation of PEX, based on the Extension Protocol.[10]
- Bitflu[11]
- BitTorrent[12]
- KTorrent has implemented full μTorrent PEX support as of 2.1 RC1[13]
- libtorrent and clients based on it (Deluge,[14] qBittorrent,[15] MooPolice[16]) compatible with μTorrent
- Tixati
- μTorrent[17]
- Opera 9.5, μTorrent PEX support[18]
- qBittorrent, μTorrent PEX support[19]
- rTorrent[20]
- Transmission (compatible with both the μTorrent and Vuze implementations)[21]
- XTorrent being based on Transmission source code, equally fully supports the Vuze and μTorrent implementations as of version 1.0 (v40)[22]
References
[edit]- ^ "Peer Exchange - VuzeWiki".
- ^ "Azureus messaging protocol - VuzeWiki". wiki.vuze.com. Retrieved 2019-11-20.
- ^ "extension_protocol.rst". www.rasterbar.com. Retrieved 2019-11-20.
- ^ a b "BitTorrentPeerExchangeConventions - Theory.org Wiki". wiki.theory.org. Retrieved 2019-11-20.
- ^ <the8472.bep@infinite-source.de>, The 8472. "bep_0011.rst_post". www.bittorrent.org. Retrieved 2021-05-23.
{{cite web}}
: CS1 maint: numeric names: authors list (link) - ^ "Bitcomet - Changelog".
- ^ "Ubuntu Manpage: Aria2c - the ultra fast download utility". Archived from the original on 2015-04-02. Retrieved 2015-03-29.
- ^ "utorrent PEX in Vuze". Vuze Wiki website. Retrieved 2010-08-15.
- ^ "PEX in BitComet". BitComet Wiki website. Retrieved 2010-02-23.
- ^ "Release notes for BitComet". BitComet official website. Retrieved 2010-02-23.
- ^ "Bitflu configuration example". Retrieved 2007-03-30.
- ^ BitTorrent User Manual - Appendix A: The BitTorrent Interface - Miscellaneous - Torrent Properties - General - Other Settings - Peer Exchange Archived 2014-07-06 at the Wayback Machine
- ^ "What's new in 2.1?". KTorrent official website. Archived from the original on 2006-04-02. Retrieved 2007-03-30.
- ^ "Deluge 0.5.1 Beta 1 changes". Archived from the original on 2008-12-25. Retrieved 2007-09-11.
- ^ "qBittorrent official website". Retrieved 2007-05-14.
- ^ "MooPolice official website". Retrieved 2007-03-30.
- ^ "μTorrent 1.4.1 beta and 1.4.2 beta changes". Archived from the original on 2006-11-25. Retrieved 2007-09-11.
- ^ "Opera 9.5 BitTorrent support". Retrieved 2007-09-04.
- ^ "Details of qBittorrent package". Debian Packages. Retrieved 2011-04-15.
μTorrent-compatible Peer eXchange (PeX)
- ^ "libTorrent 0.11.8 and rTorrent 0.7.8 Changelog". Archived from the original on 2007-11-03. Retrieved 2007-09-11.
- ^ "NEWS (rev 1579)". Transmission SVN. Archived from the original on 2007-08-24. Retrieved 2007-03-30.
- ^ Xtorrent P2P (for Mac OS X)