In a client-server network adapted to provide content, such as hypertext markup language (HTML) pages to clients, many clients may concurrently connect with a server. The processing capacity of a server in such a network is limited. If the number of clients connected to the server exceeds the processing or transmission capacity of the server, the media server may be unable to provide a high quality of service to the clients, crash, discontinue service to clients, or refuse connections to clients.
Peer-to-peer networking solutions reduce or eliminate capacity deficiencies that are common in client/server network configurations. Peer-to-peer network technologies distribute processing and transmission demands among peer clients in the network. Thus, as a peer-to-peer network grows in size, so to does the processing and transmission capacity of the peer-to-peer network.
Traditional web page browsers download a web page from a web server. If the web page contains more content to be displayed, such as images, macromedia flash files in embedded flash players, multimedia files in embedded windows media players, or the like, the browser activates additional downloading processes and downloads these files. This download process may consume an undesirable amount of time, particularly when the multimedia files are large in size.
Aspects of the present disclosure are best understood from the following detailed description when read with the accompanying figures, in which:
It is to be understood that the following disclosure provides many different embodiments, or examples, for implementing different features of various embodiments. Specific examples of components and arrangements are described below to simplify the present disclosure. These are, of course, merely examples and are not intended to be limiting. In addition, the present disclosure may repeat reference numerals and/or letters in the various examples. This repetition is for the purpose of simplicity and clarity and does not in itself dictate a relationship between the various embodiments and/or configurations discussed.
The mechanism for downloading files and content embedded therein for a conventional web browser includes accessing the source server(s) directly. As numerous clients access the source server, the quality of service of the source server may be adversely effected. The downloading process may often consume a substantial time to complete the retrieval of files from the source server.
Each of content servers 230-232 may provide content delivery services for a finite number of clients, and thus the client service capacity of cluster 250 is limited to the aggregate service capacity of content servers 230-232. If the demand placed on cluster 250 becomes too large, the service quality provided to clients 220-224 may be degraded or one or more of clients 220-224 may be disconnected from cluster 250. Conventional solutions for addressing excessive loads placed on cluster 250 generally include expanding the processing capacity of cluster 250, for example by adding additional content servers to cluster 250, upgrading the capacity of existing content servers, or by other mechanisms. Such system reconfigurations are costly due to both hardware and labor expenses.
Control server 331 may facilitate connection of new clients within network 300 and organize clients 310-317 that have joined network 300. Clients 310-317 may be implemented as data processing systems, such as personal computers, wired or wireless laptop computers, personal digital assistants, or other computational devices capable of network communications.
Content source 332 may be implemented as a server that stores or accesses content, such as HTML content, streaming video, audio, or the like, and transmits the data to one or more clients in network 300. For example, the content may be retrieved from a file that is accessed by content source 332 from a storage device 360. Content source 332 may divide content into data segments that are distributed within network 300 as described more fully below. Various clients 310-317 may receive and store different data blocks of the content.
Control server 331 maintains a peer list 370 that includes connectivity information, such as a network address and port number, of respective peer clients that are connected within peer-to-peer network 200. When control server 331 generates peer list 370, connectivity information of content source 332 may be the only connectivity information included in peer list 370. A client joins peer-to-peer network 300 by first connecting with control server 331 and submitting a request for peer list 370. The control server returns peer list 370 to the requesting client, and the client joins network 300 by selecting one or more nodes having connectivity information included in peer list 370 and connecting with the selected nodes.
When a new client joins peer-to-peer network 300, control server 332 may add connectivity information of the newly joining client to peer list 370. In this manner, as additional clients join peer-to-peer network 300, the availability of peer clients with which subsequently joining clients may connect is increased. Connectivity information of content source 332 may be removed from peer list 370, for example when the number of clients connected within peer-to-peer network 300 reaches a pre-defined threshold. In this manner, the load placed on content source 332 may be reduced. A client connected within peer-to-peer network 300 that desires content originally provided by content source 332 may submit a query for the content to peer clients with which the requesting client is connected. If no peer clients within network 300 have the requested content (or no peer clients within network 300 are available for delivery of the content to the requesting client), the requesting client may obtain the content from content source 332.
A peer client that receives content from content source 332 may be configured to cache or temporarily store the content (or a portion thereof) for playback. Additionally, a client may distribute cached streaming content to other peer clients. Content may be segmented by content source 332 into data blocks or segments that each have an associated sequence number. Playback or display of content is performed by arranging data blocks into a proper sequence based on the data blocks' sequence numbers. Network 300 may comprise a transient Internet network, and thus clients 310-317, control server 331, and content source 332 may use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. Alternatively, network 300 may be implemented in any number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN). Additionally, control server 331 and content source 332 are shown as distinct entities within network 300. However, control server 331 and content source 332 may be collectively implemented in one or more common network nodes.
Embodiments disclosed herein provide mechanisms for downloading web content within a peer-to-peer network. Advantageously, the load of the source server which originates the content may be reduced as the content is distributed within the peer-to-peer network and the downloading speed within the peer-to-peer system may be increased.
Notably, the location of content, such as a web page, within peer-to-peer network 400 is not specified by a file URL but rather by the association of the URL, or other suitable identifier, with a peer node identifier, such as a peer node address. In other implementations, a peer client may use an identifier derived from a file URL as a content identifier rather than the URL itself.
In some implementations, a peer node and URL association may not uniquely determine a file location within network 400. For example, a source server that originated a particular file may change the file that is located at a particular URL for providing another web service or other content. In order to provide a unique identifier for the file, a peer client may connect to the source server and retrieve the file size and the last modification time of the file. The client then uses a combination of file URL, file size and file's last modification time as an identifier of the file or a derived format of the combination. Accordingly, indexing server 404 may maintain additional information related to content maintained in network 400 in association with the content identifier and identifications of peer node(s) that maintain the content. For example, indexing server 404 may maintain file size and modification time in association with an identifier of the file or content and identifications of any peer nodes that maintain the content within network 400.
In addition to connectivity data of any peer nodes and/or a content source, such as web server 405, that maintains requested content, a peer list generated by indexing server 404 may include connectivity information of mirror sites of the content source. Directing peer nodes to retrieve content from a mirror site may facilitate a reduction in the load placed on the source server.
If there are available peers in the peer list returned to peer client 440 from indexing server 404, client 440 may then connect to one or more of the peers identified in the peer list, send a query with the file identifier to the peers, and retrieve the file, or a portion thereof, from the peers. If the client retrieves only a portion of the file, the client may specify start and end positions of the file, e.g., by way of specifying particular data blocks or segments of the file.
Other peers, such as peer nodes 406-410 in peer-to-peer network 400 may be configured in a similar manner as peer node 403 and thus may retrieve content in a similar manner as that described with regard to peer node 403. Additionally, peer nodes 403 and 406-410 may provide uploading services within network 400. A peer client preferably listens at a particular port and waits for connections from other peer nodes within network 400. In this manner, requests for content from other peer nodes is made over the port, and a peer node may then provide other peer nodes with uploading service in response to a request for content.
When a peer client downloads content of a file, either from other peers or from the source server, it may save the file or portion of the file into a file cache. In this manner, the peer client may provide uploading service of the file. The peer client may determine whether to save a downloaded file according to some pre-defined rule, e.g., based on the client's free disk space, the client's bandwidth, etc. If the peer client does save the file, or a portion thereof, the peer client preferably reports information of the saved file to indexing server 404. Indexing server 404 may update database 420 to indicate that the client currently has the file stored and available for upload to other peer clients.
If the peer list does not specify any peer node, the peer client may retrieve the file from the source server or a mirror site thereof (step 516). For example, connectivity information of mirror sites of a source server may be included in the peer list to facilitate reducing the load placed on the source server. If no peer nodes or mirror sites are specified in the peer list, the peer client processing routine may pass control back to the browser such that the browser connects with the source server, e.g., according to the URL of the original browser request. After retrieving the content from the source server or a mirror site thereof, the peer client may proceed to cache the retrieved content (step 518) to make the content available for other peer clients.
Returning again to step 512, if the peer list does identify peer nodes that have the requested content, the peer client may then proceed to connect to one or more of the peer nodes identified in the peer list and retrieve the requested content therefrom (step 514). After the data is downloaded from the one or more peers, the peer client may cache the retrieved content according to step 518.
The peer client may report information, e.g., the content identifier, size, content segment identifiers, or the like, regarding content that is cached to the indexing server (step 520). The client processing routine may then proceed to await another browser request (step 522).
Information reported to the indexing server according to step 520 regarding cached content is saved by the indexing server in a record or other data structure to properly indicate the content maintained by the reporting peer client. When a peer client requests a peer list for particular content, the indexing server retrieves correlated data records from the database, and returns a peer list to the requesting peer client. Each peer record of a peer list includes connection information, such as IP address and listening port, of a peer maintaining the requested content.
To enhance the reliability of information provided in peer lists to querying peer nodes, the indexing server may record online status information of peer nodes within the peer-to-peer network. To this end, each peer node may report its online status to the indexing server upon joining the peer-to-peer network. Likewise, a peer node may report its imminent exit from the network prior to exiting the peer-to-peer network. The indexing server preferably maintains the online status of each peer node.
In another embodiment, a peer client may download a portion of content from one source and another portion (or portions) from another source (or sources). For example, a peer client may download an HTML page from a source server of the HTML page, and download embedded content of the HTML page from one or more peer clients in a peer-to-peer network. In this method, downloading of data intensive portions of an HTML page are effectively offloaded to the peer-to-peer network thereby decreasing the load placed on the source server of the HTML page.
As noted above, embodiments of the present disclosure are implemented by capturing a request for a file or other data structure submitted through a web browser. To this end, the peer client may register callbacks, include a modified system configuration, and/or include modifications of a web browser. Three exemplary mechanisms for capturing the request from the web browser are described below. The first two example embodiments may be implemented on MICROSOFT INTERNET EXPLORER web browser, and the third mechanism may be applicable to Internet Explorer or for other browsers.
Each of BHOs 620-623 may perform respective functions that facilitate exchange of content in a peer-to-peer network in accordance with embodiments disclosed herein. For example, BHO 620 may provide functionality that detects a web browser control event, such as a navigate event that indicates browser 604 will soon navigate to a new web site, and that obtains information from the event. For example, BHO 620 may retrieve the URL from a browser control event that identifies a network location which the browser will navigate to without further intervention by one of BHOs 620-623. BHO 620 may pass the obtained URL to another BHO, such as one or more of BHOs 621-623. Other BHOs, such as BHO 621, may provide functionality for temporarily suspending or interrupting browser functionality by interfacing with the browser control to suspend the imminent navigation to a new site. Still other BHOs may generate a content identifier and query the indexing server with the content identifier, while another BHO may process a peer list returned from the indexing server. Yet another BHO may be responsible for instigating connections with other peer nodes for retrieval of the requested content and passing the content to web browser 604. The BHOs depicted are exemplary only and functionality of the present embodiment may be implemented in one or more BHOs.
In another embodiment, a permanent protocol handler may be registered for the web browser, such as Internet Explorer. In this implementation, a registration item or method for a protocol is registered in the operating system, such as MICROSOFT WINDOWS. When the browser receives data formatted according to the protocol, the registered method associated with the protocol is loaded by the browser and processing of the data is passed to the method. The method includes logic for performing data exchange in a peer network as described above.
In yet another embodiment, a proxy of a web browser may be utilized to perform data exchange by a peer network. Many commercially available browsers have methods to setup proxy configurations. In this implementation, a proxy may be configured to pass processing to a module of the peer client from the browser, and the peer client may then take over data retrieval functions from the web browser. For example, the proxy may invoke methods, subroutines, or other logic that suspends retrieval functions of the web browser upon detection of a browser event, such as the beginning of a navigate event, and that passes control of data retrieval or exchange from the web browser to logic of the peer client.
In accordance with an embodiment of the present disclosure, a peer client may selectively determine whether an attempt to retrieve requested content (or a portion thereof) is to be made from the peer-to-peer network. For example, the peer client may be configured to attempt retrieval of only data intensive content, e.g., media files such as shockwave Flash files, MPEG-formatted files, or other media content, from the peer-to-peer network. Accordingly, after capturing a request from a web browser, the peer client may evaluate the particular request and determine whether the content should be retrieved from the peer-to-peer network or the source server (or a mirror site thereof). For example, the peer client may be configured with one or more file extensions that are to be retrieved, if possible, from the peer-to-peer network.
In another embodiment of the present disclosure, the display speed of content within a web browser may be accelerated by retrieving large files in data blocks or segments.
As described, embodiments disclosed herein provide mechanisms for obtaining a request for content submitted through a browser. Control of the download process may be seized or otherwise appropriated to a peer client application. The peer client application may obtain an identifier of the requested content from the browser request. The peer client may then interrogate an indexing server with the content identifier. A peer list may be returned to the peer client that indentifies peer nodes in the peer-to-peer network that store the requested content, or a portion thereof. The peer client may then initiate connections with one or more of the peer clients for retrieval of at least a portion of the requested content. Accordingly, downloading of requested content may be offloaded to the peer-to-peer network thereby reducing the load placed on a source server of the requested content.
Although embodiments of the present disclosure have been described in detail, those skilled in the art should understand that they may make various changes, substitutions and alterations herein without departing from the spirit and scope of the present disclosure. Accordingly, all such changes, substitutions and alterations are intended to be included within the scope of the present disclosure as defined in the following claims.
This patent application claims the benefit of provisional U.S. Patent Application Ser. No. 60/662,131, filed Mar. 15, 2005, and provisional U.S. Patent Application Ser. No. 60/719,423, filed Sep. 22, 2005.
Number | Date | Country | |
---|---|---|---|
60662131 | Mar 2005 | US | |
60719423 | Sep 2005 | US |