Most of the content sharing applications use the client/server model in which all of group managements are done by the server and this sometimes becomes a communication bottleneck. Installing specialized software for different purposes such as file sharing, video conferencing etc., becomes a barrier for the user. Recent technologies like NodeJs and Socket.io have fostered new ideas the ways web browsers can be used. Moreover, the emerging standards of WebRTC open up new paradigm of direct communication channel between web browsers without relaying the data through a web server. But there are certain issues such as lack of full-fledged threading/concurrency support in the JavaScript language, reliance on synchronous loading etc. that restricts modern day browsers to take full advantage of current multiprocessing capabilities. Although, on one hand there are advantages of using web browsers, such as no requirement of specialized software, benefits of emerging technologies etc., the aforementioned issues pose challenges in implementation in certain areas. In this paper, we have tried to couple the benefits of peer-to-peer (P2P) architecture (elimination of centralized dependency, better scalability, shareability etc.) along with the advantages of recent web technologies (NodeJs, WebRTC etc.) by designing and implementing a browser based P2P content sharing framework. We have addressed the aforementioned challenges of a browser based P2P architecture by providing a mechanism to exchange messages asynchronously and facilitating new peer joins via existing peers in the network, thus reducing the dependency on bootstrap server. Our prototypical implementation demonstrates the feasibility, efficiency and scalability of this lightweight framework, on the top of which a variety of applications can be added as a layer of functionality.
[1]
Thomas C. Schmidt,et al.
Leveraging WebRTC for P2P content distribution in web browsers
,
2013,
2013 21st IEEE International Conference on Network Protocols (ICNP).
[2]
David R. Karger,et al.
Chord: A scalable peer-to-peer lookup service for internet applications
,
2001,
SIGCOMM '01.
[3]
Henning Schulzrinne,et al.
REsource LOcation And Discovery (RELOAD) Base Protocol
,
2014,
RFC.
[4]
David Trimm,et al.
Implementing a Distributed Peer to Peer File Sharing System using CHEWBACCA – CHord , Enhanced With Basic Algorithm Corrections and Concurrent Activation
,
2003
.
[5]
Thomas C. Schmidt,et al.
Let Our Browsers Socialize: Building User-Centric Content Communities on WebRTC
,
2014,
2014 IEEE 34th International Conference on Distributed Computing Systems Workshops (ICDCSW).
[6]
Ian Clarke,et al.
Freenet: A Distributed Anonymous Information Storage and Retrieval System
,
2000,
Workshop on Design Issues in Anonymity and Unobservability.
[7]
Ravi Sundaram,et al.
Maygh: building a CDN from client web browsers
,
2013,
EuroSys '13.