System providing faster and more efficient data communication
First Claim
1. A method for use with a group of clients for data communication between a web server storing a content and a requesting client via one or more clients selected from the group, for use with a first server, and where the web server, the requesting client, the first server, and the clients in the group are communicatively coupled via the Internet and each is identified in the Internet using a distinct identifier, further for data communication between a second web server storing a second content and having an identifier in the Internet and one of the clients via the requesting client, the method comprising the steps of:
- (a) each of the clients in the group sending its identifier to the first server;
(b) the first server receiving and storing the identifiers of the clients in the group;
(c) the requesting client sending its identifier and the web server identifier to the first server;
(d) the first server selecting one of the clients from the group based on associating the identifiers of the clients with the web server identifier;
(e) the first server sending the identifier of the selected client to the requesting client;
(f) the selected client receiving the content from the web server;
(g) the requesting client receiving the content from the selected client;
(h) the requesting client sending its identifier to the first server;
(i) the first server storing the requesting client identifier;
(j) the one of the clients sending the second web server identifier to the first server; and
(k) the first server sending the identifier of the requesting client to the one of the clients.
4 Assignments
0 Petitions
Accused Products
Abstract
A system designed for increasing network communication speed for users, while lowering network congestion for content owners and ISPs. The system employs network elements including an acceleration server, clients, agents, and peers, where communication requests generated by applications are intercepted by the client on the same machine. The IP address of the server in the communication request is transmitted to the acceleration server, which provides a list of agents to use for this IP address. The communication request is sent to the agents. One or more of the agents respond with a list of peers that have previously seen some or all of the content which is the response to this request (after checking whether this data is still valid). The client then downloads the data from these peers in parts and in parallel, thereby speeding up the Web transfer, releasing congestion from the Web by fetching the information from multiple sources, and relieving traffic from Web servers by offloading the data transfers from them to nearby peers.
176 Citations
25 Claims
-
1. A method for use with a group of clients for data communication between a web server storing a content and a requesting client via one or more clients selected from the group, for use with a first server, and where the web server, the requesting client, the first server, and the clients in the group are communicatively coupled via the Internet and each is identified in the Internet using a distinct identifier, further for data communication between a second web server storing a second content and having an identifier in the Internet and one of the clients via the requesting client, the method comprising the steps of:
-
(a) each of the clients in the group sending its identifier to the first server; (b) the first server receiving and storing the identifiers of the clients in the group; (c) the requesting client sending its identifier and the web server identifier to the first server; (d) the first server selecting one of the clients from the group based on associating the identifiers of the clients with the web server identifier; (e) the first server sending the identifier of the selected client to the requesting client; (f) the selected client receiving the content from the web server; (g) the requesting client receiving the content from the selected client; (h) the requesting client sending its identifier to the first server; (i) the first server storing the requesting client identifier; (j) the one of the clients sending the second web server identifier to the first server; and (k) the first server sending the identifier of the requesting client to the one of the clients. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22)
-
-
23. A method for use with a group of clients for data communication between a web server storing a content and a requesting client via one or more clients selected from the group, for use with a first server, and where the web server, the requesting client, the first server, and the clients in the group are communicatively coupled via the Internet and each is identified in the Internet using a distinct identifier, and further for data communication between a second web server storing a second content and having an identifier in the Internet and one of the clients via the requesting client, the method comprising the steps of:
-
(a) each of the clients in the group sending its identifier to the first server; (b) the first server receiving and storing the identifiers of the clients in the group; (c) the requesting client sending its identifier and the web server identifier to the first server; (d) selecting one of the clients from the group based on the geographical location of the clients; (e) the first server sending the identifier of the selected client to the requesting client; (f) the selected client receiving the content from the web server; (g) the requesting client receiving the content from the selected client; (h) the one of the clients sending the second web server identifier to the first server; (i) the first server sending the identifier of the requesting client to the one of the clients; (j) the requesting client receiving the second content from the second web server; and (k) the one of the clients receiving the second content from the requesting client. - View Dependent Claims (24, 25)
-
Specification