This invention relates generally to peer-to-peer services, more particularly, to methods, apparatus, and systems for peer-to-peer services with known peers.
File transfers in a network computer system is a well-known concept For example, in the early days of the Internet, file transfers were accomplished by connecting to a destination computer and executing a file transfer command (e.g. FTP). This type of data transfer can be referred to as a client-server model.
The client-server model of data transfer has disadvantages and faults. For example, if one server or several servers store copies, i.e., mirrors, of a file(s), these server(s) can be rapidly overwhelmed in response to a spike of popularity of the file(s). Accordingly, the user experience in obtaining these file(s) may be less than satisfactory.
Peer-to-peer (P2P) systems offer advantages over the traditional client-server model. A P2P computer network is a network that relies primarily on the computing power and bandwidth of the participants in the network rather than concentrating it in a relatively low number of servers. P2P networks are typically used for connecting nodes via largely ad hoc connections. Such networks are useful for many purposes.
Although P2P networks can offer greater bandwidth and availability of files, there are still drawbacks and disadvantages. For example, since a selected file is distributed among the peers in a given P2P network, a file download may not ever be completed if the peer that has the missing segment does not participate in the P2P network or is not online at the same time as the user Moreover, a user may not be ensured that a segment may be infected with malicious software (malware such as spyware, viruses, etc.). Accordingly, there is need for a P2P network system that provides a measure of security as well as availability.
Various features of the embodiments can be more fully appreciated, as the same become better understood with reference to the following detailed description of the embodiments when considered in connection with the accompanying figures, in which:
For simplicity and illustrative purposes, the principles of the present invention are described by referring mainly to exemplary embodiments thereof However, one of ordinary skill in the art would readily recognize that the same principles are equally applicable to, and can be implemented in, all types of networked computer systems, and that any such variations do not depart from the true spirit and scope of the present invention. Moreover, in the following detailed description, references are made to the accompanying figures, which illustrate specific embodiments. Electrical, mechanical, logical and structural changes may be made to the embodiments without departing from the spirit and scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense and the scope of the present invention is defined by the appended claims and their equivalents.
Embodiments relate generally to methods, apparatus, and systems for providing peer-to-peer (P2P) services with known peers. More particularly, a secure P2P module may be configured to provide substantially the same services as current P2P networks. However, the secure P2P module retrieves data from known peers of the user. More particularly, the secure P2P module may provide the requested P2P service from a set of known peers that the user has predetermined. In some embodiments, the set of known peers may be derived from a social network that the user is a member of. Moreover, the secure P2P module may only allow known peers to access the computer of the user. In effect, the secure P2P module may function as a guardian allowing only approved peers to access data to and from the associated computing device of the user.
As shown in
The peers 105 may be a collection of computing platforms that may participate in a peer-to-peer (P2P) network. The peers 105 may be implemented with personal computers, workstations, thin clients, thick clients, or other similar computing devices. The peers 105 may use an operating system 115 such as LINUX®, WINDOWS®, MACINTOSH® or other available operating systems known to those skilled in the art. Each peer 105 may also execute a peer-to-peer overlay 120 on the operating system 115. The peer-to-peer overlay 120 may be configured to provide the P2P services for each respective peer. The peer-to-peer overlay 120 may implement P2P services such as Bit-Torrent, KaZaa, Napster, a content-addressable network (CAN), CHORD, or other similar P2P protocol. Of note, in addition to typical public torrents, the torrent used by embodiments of the present invention can be private or secure (e.g., personal video). The peers 105 may also execute a social network client 125. The social network client 125 provides the data necessary for a user to participate in a social network such as YOUTUBE.COM, MYSPACE.COM, or other similar social networks.
The system 100 also includes user platform 130, which is also coupled with the network 110. The user platform 130 may be selected from the peers 105 or be similar in operating characteristics with the peers 105. As such, the user platform 130 may include operating system 115 and social network client 125 as with the peers 105. The operating system 115 may be configured to provide a software framework to provide services, such as, instant messaging, downloading or playback of files. The operating system 115 may be implemented with known operating systems such as LINUX®, WINDOWS®, MACINTOSH® or other available operating systems known to those skilled in the art. The social network client 125 provides the data necessary for a user to participate in a social network such as YOUTUBE.COM, MYSPACE.COM, or other similar social networks. The user platform 130 may be implemented with personal computers, workstations, thin clients, thick clients, or other similar computing platform.
In some embodiments, the user platform 130, among other functionalities, may execute a secure peer-to-peer (P2P) module 135. The secure P2P module 135 may be configured to provide a user with the same P2P services as with the peer-to-peer overlay 120 that provide for conventional P2P networks (e.g., Bit-Torrent, KaZaa, CHORD, CAN and Freenet) but within a user-selected subset of the peers 105. More particularly, the user of the user platform 130 may participate in a social network 140. The social network 140 may include a subset of the peers 105. Accordingly, when the user invokes the secure P2P module 135, the secure P2P module 135 provides any requested P2P service from the subset of peers as defined by the participants in the social network 140. Alternatively, the secure P2P module 135 may provide a mechanism for a user to select a group of peers. For example the secure P2P module 135 may provide for a user interface that allows a user to select the members of the set of known peers.
As shown in
The memory 210 may be configured to provide a storage function for the secure P2P module 135. The memory 210 may be used, among other uses, as storage for downloaded files or as a temporary buffer for files being used for P2P services. The memory 210 may also store a software application that provides the functionality of the secure P2P module 135. The memory 210 may be implemented using high speed memory such as dynamic random access memory or other similar technologies. In alternative embodiments, the memory 210 may be allocated in the main memory by the underlying operating system in response to the invocation of the secure P2P module 135.
The interface 215 may be configured to provide a communication port for the control module 205 to interact with the operating system as well as the peers 105. The interface 215 may be implemented as a standard interface such as peripheral control interface, Small Computer System Interface (SCSI), IEEE 1394 in hardware embodiments or a software port in software embodiments.
Accordingly, the control module 205 may be configured to receive a request for a P2P service. The control module 205 may retrieve a file which stores the information related to the participants of the social network of a user. The control module 205 may then start the P2P overlay service based on the peer information from the retrieved file. As noted previously, the P2P service can be a file playback or download or other P2P services. For example, a user may execute a file download (e.g., music, video, application program, etc.). The secure P2P module 135 begins the download of the file only from the peers associated the participants in the social network of the user.
As shown in
In step 310, the control module 205 may be configured to display the list of the participants for the user. For example, the control module 205 may display a dialog box requesting the user to select from the list of participants in the social network to form a set of known peers. The dialog box may include a button configured to include all the participants in the set of known peers. The dialog box may also include a selection mechanism to select participants in the set of known peers.
In step 315, the control module 205 may be configured to wait for a user to initiate the creation of the set of known peers. Continuing with the previous example, the dialog box may include another button that initiates the creation of the set of known peers after the user has completed the selection thereof.
In step 320, the control module 205 may be configured to create the list of known peers and store in the memory 210.
As shown in
In step 415, the control module 205 may be configured to invoke the requested P2P service. More particularly, the control module 205 may initiate the requested P2P service with only the set of known peers to provide the requested P2P service.
As shown in
Certain embodiments may be performed as a computer program. The computer program may exist in a variety of forms both active and inactive. For example, the computer program can exist as software program(s) comprised of program instructions in source code, object code, executable code or other formats; firmware program(s); or hardware description language (HDL) files. Any of the above can be embodied on a computer readable medium, which include storage devices and signals, in compressed or uncompressed form. Exemplary computer readable storage devices include conventional computer system RAM (random access memory), ROM (read-only memory), EPROM (erasable, programmable ROM), EEPROM (electrically erasable, programmable ROM), and magnetic or optical disks or tapes. Exemplary computer readable signals, whether modulated using a carrier or not, are signals that a computer system hosting or running the present invention can be configured to access, including signals downloaded through the Internet or other networks. Concrete examples of the foregoing include distribution of executable software program(s) of the computer program on a CD-ROM or via Internet download. In a sense, the Internet itself as an abstract entity, is a computer readable medium. The same is true of computer networks in general.
While the invention has been described with reference to the exemplary embodiments thereof, those skilled in the art will be able to make various modifications to the described embodiments without departing from the true spirit and scope. The terms and descriptions used herein are set forth by way of illustration only and are not meant as limitations. In particular, although the method has been described by examples, the steps of the method may be performed in a different order than illustrated or simultaneously. Those skilled in the art will recognize that these and other variations are possible within the spirit and scope as defined in the following claims and their equivalents.
Number | Name | Date | Kind |
---|---|---|---|
6549937 | Auerbach et al. | Apr 2003 | B1 |
6839769 | Needham et al. | Jan 2005 | B2 |
6973299 | Apfel | Dec 2005 | B2 |
7068789 | Huitema et al. | Jun 2006 | B2 |
7234117 | Zaner et al. | Jun 2007 | B2 |
7340500 | Traversat et al. | Mar 2008 | B2 |
7343418 | Herley | Mar 2008 | B2 |
7451186 | Morinigo et al. | Nov 2008 | B2 |
7523385 | Nguyen et al. | Apr 2009 | B2 |
7526459 | Flinn et al. | Apr 2009 | B2 |
7782866 | Walsh et al. | Aug 2010 | B1 |
7836183 | Barnett et al. | Nov 2010 | B1 |
7930347 | Maxwell et al. | Apr 2011 | B2 |
7958250 | Sridhar et al. | Jun 2011 | B2 |
8280913 | Bergin | Oct 2012 | B2 |
20020156893 | Pouyoul et al. | Oct 2002 | A1 |
20020165815 | Vincent | Nov 2002 | A1 |
20030101235 | Zhang | May 2003 | A1 |
20040041836 | Zaner et al. | Mar 2004 | A1 |
20050091202 | Thomas | Apr 2005 | A1 |
20050216550 | Paseman et al. | Sep 2005 | A1 |
20060048059 | Etkin | Mar 2006 | A1 |
20060117378 | Tam et al. | Jun 2006 | A1 |
20070168433 | Morgan | Jul 2007 | A1 |
20070211651 | Ahmed et al. | Sep 2007 | A1 |
20070214259 | Ahmed et al. | Sep 2007 | A1 |
20070239819 | Woods et al. | Oct 2007 | A1 |
20070275696 | Cheng et al. | Nov 2007 | A1 |
20080043634 | Wang et al. | Feb 2008 | A1 |
20080117861 | Balandina et al. | May 2008 | A1 |
20080184030 | Kelly et al. | Jul 2008 | A1 |
20080196087 | Ranjit | Aug 2008 | A1 |
20090262668 | Hemar et al. | Oct 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20080130522 A1 | Jun 2008 | US |