Search code examples
c++network-programmingp2prouterpeer

The most important basics of P2P


I've been reading around on the www but just can't get the most important basics of P2P.

The diagram is like this:

[peer1]<-->[dsl-router1]<-->[central server]<-->[dsl-router2]<-->[peer2]

I'm developing a chat software on the central server. Chat messages being transfered thru' the central server well by now, however, I need to make the p2p file sharing feature because the bandwidth (the cable bandwith, not the transfer limit) of the server supposed for transfering chat messages only.

The problem is that, my software on central server knows the IPs and ports of router1 and router2, but not the peer1 and peer2 as these peers are behind the routers and don't have IP addresses.

How to actually transfer some data from peer1 to peer2 and vice versa without having this data passing thru' central server?

(and the worst case is that there is a wireless router between peer and dsl-router)


Solution

  • There are two basic ways of doing this. The new way is to use IGDP (opening a port via uPnP). This is described quite well here:

    http://www.codeproject.com/Articles/13285/Using-UPnP-for-Programmatic-Port-Forwardings-and-N

    If neither of the two nodes have a router supporting uPnP then another alternative is TCP hole punching, which is not perfect but works quite well in practice. This is described here:

    http://www.brynosaurus.com/pub/net/p2pnat/