WO2010110794A1 - Conditional protocol control - Google Patents

Conditional protocol control Download PDF

Info

Publication number
WO2010110794A1
WO2010110794A1 PCT/US2009/038361 US2009038361W WO2010110794A1 WO 2010110794 A1 WO2010110794 A1 WO 2010110794A1 US 2009038361 W US2009038361 W US 2009038361W WO 2010110794 A1 WO2010110794 A1 WO 2010110794A1
Authority
WO
WIPO (PCT)
Prior art keywords
protocol
content
attributes
connection
network
Prior art date
Application number
PCT/US2009/038361
Other languages
French (fr)
Inventor
Bradley B. Harvell
Joseph D. Depalo
Michael M. Gordon
Original Assignee
Limelight Networks, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Limelight Networks, Inc. filed Critical Limelight Networks, Inc.
Priority to PCT/US2009/038361 priority Critical patent/WO2010110794A1/en
Priority to US12/572,981 priority patent/US8274909B2/en
Priority to US12/625,436 priority patent/US7715324B1/en
Publication of WO2010110794A1 publication Critical patent/WO2010110794A1/en
Priority to US13/595,904 priority patent/US8750155B2/en
Priority to US14/300,076 priority patent/US9100463B2/en
Priority to US14/754,453 priority patent/US20160156741A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1069Session establishment or de-establishment

Definitions

  • This disclosure relates in general to interoperating nodes in an information processing system, such as an Internet content delivery system or an Internet transaction acceleration system, and, but not by way of limitation, to control of connection protocols.
  • two or more nodes can work together, for example exchanging information or sharing resources, using one or more protocols that enable the participating nodes to interoperate.
  • Nodes need not be physically distinct from one another, though they may be; normally, however, nodes are at least logically distinct from one another in at least some respect.
  • Interoperating nodes may be operated or managed by a single common authority or by independent, unrelated authorities. Two or more interoperating nodes are often independently operated or managed; the Internet includes many well known examples of the interoperation of two or more independently managed nodes.
  • a protocol can be standardized such that a node using the standard protocol should be able to interoperate, at least at the level of the protocol, with any other node using the standard protocol.
  • Standard protocols that become widely adopted can permit a node to interoperate with many other nodes.
  • One such widely adopted standard protocol on the Internet is the Transmission Control Protocol (TCP), which today enables almost every device on the Internet to interoperate with almost every other device.
  • TCP operates at the connection layer and enables nodes to interoperate with other nodes by establishing communications connections.
  • Standard protocols often employ the use of attributes, such as configurable parameters and selectable algorithms, to permit the protocol to operate effectively in various situations.
  • attributes such as configurable parameters and selectable algorithms
  • TCP controls message size, the rate at which messages are exchanged, and factors related to network congestion through the use of attributes, including both by the use of parameters, such as the receive window field used in sliding window flow control and the retransmission timer, and by the use of algorithms, such as slow-start, congestion avoidance, fast retransmit, and fast recovery algorithms.
  • the initial protocol attribute settings to be used for all the communication connections at the node can be independently specified by the operator of the node.
  • a protocol can also be customized, which in general requires that each node have installed customized components to enable the custom protocol. Without the customized components, the node would not be able to fully interoperate with other nodes using the customized protocol. Although it therefore may limit the total number of interoperable nodes, or in the alternative require widespread action to install the protocol customized components, or possibly both, protocol customization is used in order to add function, improve performance, increase flexibility, or modify other characteristics of a standard protocol, or to make available an entirely new customized protocol. Many customized protocols have been proposed for use on the Internet.
  • a system utilizing a standard protocol to enable two or more nodes to interoperate is disclosed.
  • the protocol attributes specified in the standard protocol are conditionally adapted to the circumstances, use, and/or operating conditions of the interoperation of the nodes.
  • a method is disclosed for utilizing a standard protocol to enable two or more nodes to interoperate, wherein the protocol attributes specified in the standard protocol are conditionally adapted to the circumstances, use, and/or operating conditions of the interoperation of the nodes.
  • a system for supplying content objects over a network includes a protocol handler, a protocol attribute information store, and a protocol attribute selector.
  • the protocol handler manages a first connection and a second connection over the network using a standard protocol.
  • the protocol attribute information store holds a plurality of attributes defined for a plurality of connections.
  • the protocol attribute selector receives first information based on a first request for content, identifies first attributes corresponding to the connection that will service the first request for content, provides the protocol handler with the first attributes for the connection servicing the first request for content, receives second information based on a second request for content, identifies second attributes corresponding to the connection that will service the second request for content, and provides the protocol handler with the second attributes for the connection servicing the second request for content.
  • a network connection method for delivering content is disclosed.
  • a first request for content is received over a network at a server.
  • the first request for content is evaluated to select first protocol attributes.
  • a first connection that sends the content from the server to a first node is configured according to the first protocol attributes.
  • a second request for content is received over the network at the server.
  • the second request for content is evaluated to select second protocol attributes.
  • a second connection that sends the content from the server to a second node is configured according to the second protocol attributes, where the first attributes affect the operation of the protocol differently than the second attributes affect the operation of the protocol.
  • a system for conducting transactions over a network includes a protocol handler, a protocol attribute information store, and a protocol attribute selector.
  • the protocol handler manages a first connection and a second connection over the network using a standard protocol.
  • the protocol attribute information store holds a plurality of attributes defined for a plurality of connections.
  • the protocol attribute selector receives first information based on a first transaction, identifies first attributes corresponding to the connection that will service the first transaction, provides the protocol handler with the first attributes for the connection servicing the first transaction, receives second information based on a second transaction, identifies second attributes corresponding to the connection that will service the second transaction, and provides the protocol handler with the second attributes for the connection servicing the second transaction.
  • a network connection method for conducting transactions over a network is disclosed.
  • a first transaction is initiated over a network at a server.
  • the first transaction is evaluated to select first protocol attributes.
  • a first connection, servicing the first transaction, between the server and a first node is configured according to the first protocol attributes.
  • a second transaction is initiated over the network at the server.
  • the second transaction is evaluated to select second protocol attributes.
  • a second connection, servicing the second transaction, between the server and a second node is configured according to the second protocol attributes, where the first attributes affect the operation of the protocol differently than the second attributes affect the operation of the protocol.
  • FIG. 1 depicts a block diagram of an embodiment of a content delivery system
  • FIGs. 2A, 2B, 2C, and 2D depict block diagrams of embodiments of a content download pair that sends content from a server to a client;
  • FIG. 3 illustrates a flowchart of an embodiment of a process for modification of the TCP protocol for various connections to a server
  • FIG. 4 illustrates a flowchart of an embodiment of a process for modifying protocol attributes potentially on a connection-by-connection basis is shown.
  • FIG. 1 a block diagram of an embodiment of an Internet content delivery system 100 is shown.
  • one or more nodes request content from one or more other nodes.
  • a number of end users 108 respectively use their end user system or client 102 to download and view content objects from the global Internet 104.
  • the content delivery system 110 has one or more servers that provide content object downloads.
  • the content delivery system 110 can include any number of cache servers, application servers, content servers, service servers, and/or database servers to provide content to the clients 102.
  • this embodiment shows particular communication pairs, other embodiments could communicate between any pair of nodes on a network, including between pairs of clients or between pairs of servers, and yet other embodiments could communicate among more than two nodes, such as in a broadcast or multicast implementation.
  • a content download pair 200 that sends content from a server 206 to a client 102.
  • a primary embodiment described here is the interoperation of two nodes 102, 206 on the Internet communicating using TCP, one node being a client 102 that requests information, such as web page content, multimedia, or software downloads, and the second node being a server 206 that provides information in response to a request.
  • TCP operates in the transport layer of the seven-layer Open Systems Interconnection (OSI) model.
  • OSI Open Systems Interconnection
  • nodes 102, 206 interoperate in ways other than communication in a network, such as sharing data within a computer or group of computers across an available system or intersystem interface; interoperate using communications networks other than the Internet 104, such as a private communications network; interoperate using the Internet 104 or a private network using protocols other than TCP, such as UDP, RTP, multicast protocols, and other standard protocols in the transport layer; interoperate using the Internet 104 or a private network using standard protocols operating in a layer that underlies the transport layer; interoperate, using standard protocols and the Internet or a private network, more than two at a time, such as in clusters or multicast groups; or interoperate, using standard protocols and the Internet or a private network, other than as a client and server, including interoperating as peers, as collaborative nodes, or as a group of nodes under the common control of one or more other nodes or under the common control of a controller.
  • communications networks other than the Internet 104 such as a private communications
  • the server 206 conditionally adapts the attributes of the TCP protocol for each TCP connection established by a client 102.
  • Conditionally adapting the attributes of the TCP protocol does not require changes to standard TCP protocol implementations at every node, does not require special components be installed in the TCP protocol implementation at every node, and therefore does not comprise implementing a customized protocol as previously described; rather, the primary embodiment utilizes the standard TCP protocol and the attributes implemented in it.
  • the server conditionally adapts the attributes of other transport-layer protocols for each session established by a client 102; the server conditionally adapts the attributes of other protocols that underlie the transport layer for each session established by a client 102; the server 206 conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions established by clients 102; the server 206 conditionally adapts the attributes of the TCP protocol or other protocol for connections or sessions established by groups or subsets of groups of clients 102; the client 102 conditionally adapts the attributes of the TCP protocol for each TCP connection established; the client 102 conditionally adapts the attributes of other protocols for each session established; the client 102 conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions; a node conditionally adapts the attributes of the TCP protocol or other protocol for each connection or session; a node conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions; a node conditionally adapts the attributes of the TCP protocol or other protocol for groups of
  • Software, software modifications, or equivalent function may optionally be implemented at a server, client, or node that sets the conditionally adapted protocol attributes of a connection or session, but need not be implemented at servers, clients, or nodes that passively participate in a conditionally adapted protocol connection or session.
  • Such software, software modifications, or equivalent function will only be needed if existing protocol software or other software on the server, client, or node does not provide a facility for programmatically or similarly changing attributes of the protocol that is used; in this event, software, a software modification, or equivalent facilities to provide such a programmatic or similar interface may be implemented.
  • Conditionally adapting the protocol for each connection or session, or collection of connections or sessions results in at least one node that, concurrently or over time, uses a protocol for multiple unrelated connections or sessions wherein the protocol attributes vary, at least initially and sometimes persistently, from one connection or session to another, most often varying differently from any ordinary protocol attribute variations that naturally occur from one connection or session to another through use of the standard protocol implementation among heterogeneous nodes.
  • TCP connections are established in order to use HyperText Transfer Protocol (HTTP) to communicate information requests from clients 102 to servers 206 and responses from servers 206 to clients 102.
  • HTTP is a scheme that operates above, and depends on the presence of a functioning and reliable protocol at, the transport layer of the seven-layer model developed in the Open Systems Interconnection (OSI) initiative.
  • Other embodiments use application-layer protocols other than HTTP in conjunction with TCP; use TCP alone, i.e., without HTTP; use other protocols; or, use other application-layer protocols in conjunction with other protocols.
  • HTTP utilizes Uniform Resource Locators (URLs), Uniform Resource Names (URNs), and Uniform Resource Identifiers (URIs) to identify information. URLs are used in the primary embodiment.
  • a URL begins with the scheme identifier, which identifies the namespace, purpose, and syntax of the remainder of the URL.
  • the typical scheme is "http".
  • the scheme is followed by a host field, which contains the IP address or name of the host where the requested information can be found, optionally followed by a port number, optionally followed by a path, which is an HTTP selector, optionally followed by a search portion, which is a query string.
  • the full URL is an alphanumeric string containing the scheme, host field, any optional following strings, and special characters such as ":”, "/", and "?” that are reserved for special functions such as designating a hierarchical structure in the URL.
  • Other embodiments could use different application-layer protocols such as Telnet, File Transfer Protocol (FTP), secure HTTP (HTTPS), and Simple Mail Transfer Protocol (SMTP).
  • Telnet Telnet
  • FTP File Transfer Protocol
  • HTTPS secure HTTP
  • SMTP Simple Mail Transfer Protocol
  • the server 206 bases the conditional adaptation of the attributes of the TCP protocol on the alphanumeric URL string provided by the client 102 in its information request.
  • a server, client or other node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on the application-layer protocol specified or on identifying information, equivalent to a URL, or other information provided in, or characteristic of, an information request, connection, or session.
  • a server, client or other node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on the IP address of one or more servers, clients, or nodes; on network information associated with the IP address of one or more servers, clients, or nodes, including the Autonomous System (AS) number, identity of network operator, geographic location, logical or physical network location, logical or physical network segment, or network interconnection characteristics associated with the IP address(es) of one or more servers, clients, or nodes; the geographic location of the server, client or node; and/or, the logical or physical network location of the server, client or node; the logical or physical address of the server, client or node; the logical or physical name of the server, client or node; and/or, the network or other path from or to a server, client or node.
  • AS Autonomous System
  • a server, client or node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on recent network performance measurements, including latency, jitter, packet loss, round trip time, and/or the measured variance in a network performance measurement across multiple samples; on recent measures of utilization of a network, network segment, network interface, or network port; and/or, on recent measurements of performance or utilization of a server, group of servers, or server component(s) such as memory, processor, disk, bus, intersystem interface, and/or network interface.
  • a server, client or node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on temporal factors, including time of day; day of week, month, or year; specific date; occurrence of a holiday or religious observance; occurrence of a temporal event such as a news event or sports event; seasonal occurrence; and/or a scheduled event or time period.
  • the protocol attribute selector 212 of the server 206 compares the alphanumeric URL string provided by the client 102 in its information request to a table 220 containing partial or whole URLs and identifies the most specific match from left to right that it can find in the table 220.
  • the server 206 compares a subset of the alphanumeric string, for example some or all of the characters in the query string, or the characters following the host field up to the first subsequent slash (i.e., "/"), to a table 220.
  • the client or node 102 makes a conditional adaptation of protocol attributes, using the alphanumeric URL string or a subset of it.
  • the alphanumeric URL string or a subset of it is processed to obtain a value or indicator that is used to determine a conditional adaptation of protocol attributes.
  • the information used to determine the conditional adaptation of protocol attributes is identifying information equivalent to a URL, one or more IP addresses, network information associated with one or more IP addresses, network interconnection characteristics associated with one or more IP addresses, or the geographic location, or logical or physical network location, of a server, client or node.
  • the information used to determine the conditional adaptation of protocol attributes comprises one or more recent performance measurements or thresholds related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components, or network interfaces; rates or amounts of variation in one or more performance measurements or thresholds related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components or network interfaces; rates or amounts of resource utilization, including utilization related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or components of one or more servers, clients, or nodes, groups of components of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components, or network interfaces; rates or amounts of variation in resource utilization,
  • a table 220 containing partial or whole URLs for comparison by the protocol attribute selector 212 is stored on the server 206.
  • a table 220 containing partial or whole URLs for comparison, or subsets of the alphanumeric URL string used for comparison is stored remotely from the server 206 such as the embodiment shown in FIG. 2B and the comparison of the alphanumeric URL string or subset of the alphanumeric URL string is made at the server 206, or is made at the remote table storage location or at another location and the result of the comparison, or an indicator of the result of the comparison, or the protocol attributes to be used, are returned to the server 206.
  • a table 220 or database of information used for comparison is stored at the server 206, or is stored remotely from the server 206 and one or more comparisons are made at the server 206, or are made at the remote storage location or at another location, and the results of the comparisons, or one or more indicators of the results of the comparisons, or the protocol attributes to be used, are returned to the server 206.
  • a table 220 containing partial or whole URLs for comparison, or subsets of the alphanumeric URL string used for comparison, or a database of information used for comparison is stored at a client or node 102 as is shown in FIG.
  • 2D is stored remotely from a client or node and one or more comparisons are made at the client or node 102, or are made at the remote storage location or at another location and the results of the comparisons, or one or more indicators of the results of the comparisons, or the protocol attributes to be used, are returned to the client or node 102.
  • a protocol attribute to be used, or an indicator of a protocol attribute to be used is extracted from, or derived from, a URL or equivalent identifying information used by a server, client, or node; is extracted from, or derived from, address information or a whole or partial name of a server, client, or node; is extracted from, or derived from a user name or identifier, class or type of user, group of users, or selection of users, optionally as associated with a service, server, client, or node; is extracted from, derived from, or associated with, an application or class or group of applications, a service or class or group of services, or a database or equivalent source of data or a class or group of databases or sources of data; is extracted from, or derived from, the identifier of a standard protocol, a standard protocol message (for example, a TCP SYN), the protocol-level content of a message, or protocol message headers or equivalent information; is derived from all or a part of the time, all or
  • the server, client, or node will have one or more values it can use as protocol attributes or as indicators of which protocol attributes to use; or, if there has not been a determination of a condition resulting in one or more protocol attribute values to use, then in the primary embodiment the server 206 will use the standard values for the protocol attributes as configured for the server 206, and in other embodiments, the server, client, or node will use the standard values as configured for it for some or all of the protocol attributes; the server, client, or node will use another default value for some or all of the attributes; the server, client, or node will use the last- used values for some or all of the attributes; or, the server, client, or node will use randomly, pseudo-randomly, or arbitrarily determined values for some or all of the attributes.
  • the server 206 is a cache server, typically operating in a group of cache servers, and groups of cache servers are distributed at numerous points on the global Internet.
  • the server 206 includes a cache function 208 coupled to a content cache 210 to provide caching of content for the server 206.
  • the server 206 is a cache server operating individually, or independently from other cache servers.
  • the server 206 is a content server that provides content; a content server operating in a group of content servers; a content server operating in a group of content servers distributed at numerous points on the global Internet; an application server that supports one or more applications; an application server operating in a group of application servers; an application server operating in a group of application servers distributed at numerous points on the global Internet; a service server that provides one or more services; a service server operating in a group of service servers; a service server operating in a group of service servers distributed at numerous points on the global Internet; a database server that provides data; a database server operating in a group of database servers; a database server operating in a group of database servers distributed at numerous points on the global Internet; a server operating in a heterogeneous group of servers; or, a server operating in a heterogeneous group of servers distributed at numerous points on the global Internet.
  • each server 206 has an identical copy of a table 220 containing partial or whole URLs to which the alphanumeric URL string provided by the client 102 in its information request will be matched if possible, along with an indicator of the protocol attribute values to be used when that match occurs or the actual protocol attribute values themselves to be used when that match occurs.
  • the table 220 can be modified from time to time, including adding new entries, changing the contents of existing entries, and deleting entries. Any time that a new version of the table 220 is created, copies of that version are distributed to servers 206 in the global group of cache servers.
  • the table 220 can have an expiration date and time, after which the server 206 will stop using the table 220 if it is out-of-date and has not been replaced with an updated table.
  • the conditional protocol control information is combined with other information distributed to servers 206 so as to minimize to the extent practicable the number of tables 220 that are distributed to, and synchronized among, the global group of servers; in another embodiment, this combination and minimization is not implemented; and this combination and minimization is not done in most or all other embodiments.
  • conditional protocol information may be in the form of a table 220 as in the primary embodiment, or may be in the form of multiple tables, or may be in the form of one or more data files, one or more databases, one or more calculated or derived elements, one or more calculated or derived groups of elements, one or more individual equations or formulas, one or more groups of equations or formulas, one or more individual expressions, one or more groups of expressions, one or more individual programs or routines, one or more groups of programs or routines, one or more individual listings, one or more groups of listings, and/or other forms equivalent to any of these.
  • conditional protocol control information contains partial or whole URLs to which the alphanumeric URL string provided by the client 102 in its information request will be matched if possible, along with an indicator of the protocol attribute values to be used when that match occurs or the actual protocol attribute values themselves to be used when that match occurs, and is the same for each server 206 at a location, but varies from one location to another; is the same for each server in a region, but varies from one region to another; or, is different at each server.
  • conditional protocol control information contains partial or whole URLs to which the alphanumeric URL string used by a client or node 102 will be matched if possible, along with an indicator of the protocol attribute values to be used when that match occurs or the actual protocol attribute values themselves to be used when that match occurs, and the conditional protocol control information is identical at each client or node 102; is the same for each client or node 102 in a group, but varies from one group of clients or nodes 102 to another; is the same for each client or node 102 in a region, but varies from one region to another; or, varies from one client or node 102 to another client or node 102.
  • the conditional protocol control information contains other comparison information that will be matched, if possible, along with a corresponding indicator of the protocol attribute values to be used when that match occurs or the corresponding actual protocol attribute values themselves to be used when that match occurs, and each server, client, or node has an identical copy of the conditional protocol control information; the conditional protocol control information is the same for each server, client, or node at a location, but varies from one location to another; the conditional protocol control information is the same for each server, client, or node in a region, but varies from one region to another; the conditional protocol control information is the same for each server, client, or node in a group, but varies from one group to another; or, the conditional protocol control information varies from one server, client, or node to another.
  • the comparison information can include subsets of the alphanumeric URL string; identifying information equivalent to a URL; one or more IP addresses; network information associated with one or more IP addresses; network interconnection characteristics associated with one or more IP addresses; the geographic location, or logical or physical network location, of a server, client, or node; a value of a performance measurement or threshold; a rate or amount of variation in a performance measurement or threshold; a rate or amount of resource utilization; a rate or amount of variation in resource utilization; a threshold of resource utilization; addresses, names, classes, types, or group identifiers of servers, clients, nodes, users, applications, services, databases, or other data sources; protocol identifiers, protocol message identifiers or attributes, or protocol message headers or attributes; times, dates, or intervals; and/or, sequences, ratios, progressions, equations, randomly generated data, or arbitrarily determined data.
  • conditional protocol control information is not identical at all servers, clients, or nodes
  • a system can create conditional protocol control information for each location, region, server, client, or node, and optionally can manage the distribution of the conditional protocol control information to each location, region, server, client, or node.
  • a conditional protocol information management and distribution system optionally generates, or stores, or generates and stores, protocol attributes for any or all of a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, an application, all applications, a subset of applications, a service, all services, a subset of services, a database or data source, all databases or data sources, a subset of databases or data sources, a protocol, all protocols, a subset of protocols, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some, a subset of, a subset of some of, or all of, servers, locations, regions, groups, applications, services, databases, databases
  • the CPIMDS also optionally generates, or stores, or generates and stores, one or more rules for determining which of the server, location, region, group, application, service, database or data source, protocol, client, node, or combined values to use when determining a comparison to be included in the conditional protocol control information for a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, an application, all applications, a subset of applications, a service, all services, a subset of services, a database or data source, all databases or data sources, a subset of databases or data sources, a protocol, all protocols, a subset of protocols, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some, a subset of, a subset of some of, or all of, servers,
  • conditional protocol control information can optionally include, or can optionally correlate to, an indication of for which servers, locations, regions, groups, applications, services, databases or data sources, protocols, clients, nodes, or supersets, subsets, or combinations thereof, the conditional protocol control information can be used in adapting protocol attributes.
  • the conditional protocol control information can be maintained at a single location or multiple locations; if maintained at multiple locations, each location can maintain a complete copy of all conditional protocol control information, or each location can maintain a copy of a subset of the conditional protocol control information.
  • a conditional protocol information management and distribution system can create conditional protocol control information for, and optionally distribute conditional protocol control information to, each conditional protocol control information location, groups of conditional protocol control information locations, or all conditional protocol control information locations. If conditional protocol control information locations store a subset of the conditional protocol control information, participating servers, clients, or nodes can optionally use a table, ordered table, shuffled table, directory, logical name translation system, or information obtained from, or received from, another server, client, node, or controller, to determine which conditional protocol control information location to receive conditional protocol control information from.
  • FIG. 3 an embodiment of a process 300 for modification of the TCP protocol for various connections to a server 206.
  • two nodes on the Internet communicate using TCP, one node being a client 102 that requests information in block 304, such as web page content, and the second node being a cache server 206 that provides information in response to a request.
  • the cache server 206 operates as one of a group of cache servers, and groups of cache servers are distributed at numerous points on the global Internet.
  • TCP connections are established in order to use HTTP to communicate information requests from clients 102 to servers 206 in block 304 and responses from servers 206 to clients 102.
  • HTTP utilizes URLs; each URL begins with the scheme "http", which is followed by a host field containing the IP address or name of the host where the requested information can be found, followed by a path, which will be used at the server 206 to locate the requested object or information, optionally followed by a query string.
  • the full URL typically is an alphanumeric string containing the scheme, host field, path, and any optional query string, each part of which is separated from the other parts by special characters such as ":", "/", and "?”.
  • an example URL referencing content that can be served by the cache server 206 in the primary embodiment might look like:
  • a client 102 requesting this object would send an HTTP message using an HTTP method called "GET" to the server 206 identified by the hostname "customerl .webserving.com” in block 304.
  • the server identification is accomplished through a DNS translation of the hostname into one or more IP addresses.
  • DNS Domain Name System
  • the HTTP GET message sent to the server 206 typically includes part or all of the URL that the client 102 is requesting. In block 308, some or all of the URL is compared with entries in the table 220 to determine the attributes to use for the connection as described further below.
  • the server 206 conditionally adapts the attributes of the TCP protocol for each TCP connection established by a client 102.
  • Conditionally adapting the attributes of the TCP protocol does not require changes to standard TCP protocol implementations at every node, i.e., any client 102 that supports standard TCP (which virtually all Internet and all World Wide Web clients do) can communicate with the server 206 to get the object via a conditionally adapted TCP connection, but may require a modification to the server's TCP protocol handler to allow changes to be made to the TCP protocol attributes by another program, or on a per- connection basis, or both.
  • the content serving application may require an interface enabling it to communicate conditionally adapted TCP protocol attributes to the TCP protocol handler.
  • TCP handler 214 which is a modified TCP software stack that can accept and implement changes to the TCP protocol attributes on a per-connection basis.
  • the TCP handler could be implemented in software or hardware or both, and can be implemented as part of a node or separately from the node, for example in a switch or other device that provides protocol services.
  • Conditionally adapting the protocol for each connection results in the server 206 concurrently using the TCP protocol for multiple unrelated connections, wherein the TCP protocol attributes vary, at least initially and sometimes persistently, from one connection to another.
  • the requested object or information is sent from the server 206 to the client 102.
  • the standard TCP protocol attributes pre-configured for the TCP protocol handler are used; but when the requested object or information is delivered with conditionally adapted TCP protocol attributes, the conditionally determined TCP protocol attributes are used instead of the standard pre-configured TCP attributes.
  • a typical caching content server 206 in actual operating use in a web hosting service provider environment may typically service 2,000 to 3,000 requests per second, across 100 to 200 (or more) customers. If half of these requests will use changed TCP protocol attributes and half will not, then on average, half of the connections managed by the server 206 at any one point in time would use the changed TCP protocol attributes and half would use the standard TCP protocol attributes as pre-configured in the TCP handler 214.
  • a server 206 would concurrently be operating TCP connections with six different sets of TCP protocol attributes: 50% of the connections would utilize standard pre-configured TCP protocol attributes, and 10% would utilize each of the five possible changed TCP protocol attribute sets.
  • the server 206 bases the conditional adaptation of the attributes of the TCP protocol on the alphanumeric URL string provided by the client 102 in the HTTP GET message.
  • the conditional protocol control information is in the form of a table 220 containing partial and/or whole URLs for comparison, the table 220 is stored on the server 206, and the table 220 is generally kept reconciled on all servers 206.
  • the server 206 compares the alphanumeric URL string provided by the client 102 in the GET request to the table 220 and identifies the most specific match from left to right that it can find in the table 220 in block 308.
  • the sole Table shows mappings from whole and/or partial URLs into TCP attribute sets comprising specific protocols attributes (identified as “attrl”, “attr2”, “attr3”, etc.) to be used and the appropriate value or setting for that use of that attribute.
  • This simplified table example also illustrates that the scheme and host name may be sufficient for a matching entry, such as in the case of the entry "http://customer3.webserving.com,” or the host name alone may be sufficient, such as in the case of the entry "fastnet.com.”
  • This simplified table example also illustrates that there may be a null entry in the table, as in the case of "http://customer2.webserving.com”; in this simplified table example, the null entry signifies use of the standard pre-configured TCP protocol attributes. Note that an actual table in the primary embodiment would contain more information than the simplified example table shown here, as discussed.
  • the table 220 can be modified from time to time, including adding new entries, changing the contents of existing entries, and deleting entries.
  • a new version of the table 220 is created, copies of the new version of the table 220 are distributed to the servers 206 in the global group of cache servers.
  • the table 220 can have an expiration date and time, after which the server 206 will stop using the table 220 if it is out-of-date and has not been replaced with an updated table 220; under this condition, the server 206 would then use the standard TCP protocol attributes for connections until the server 206 received an updated or unexpired table 220.
  • conditional protocol control information is combined with other information, such as customer billing codes and other customer-specific information, that is distributed to all servers 206, in order to minimize the number of tables that are distributed to, and reconciled throughout, the global group of servers.
  • This embodiment has the advantage of simplifying administration, change management, and rollback in the event that distribution of a new table 220 causes a problem or error condition, but the disadvantage that the conditional protocol adaptation is the same for any given entry in the table 220 at every server 206, regardless of the server's location or other factors.
  • the conditional protocol control information can vary from one server 206 to another.
  • FIG. 4 an embodiment of a process for potentially modifying protocol attributes on a connection-by-connection basis is shown.
  • the depicted portion of the process begins in block 416 where a uniform resource indicator (URI) is requested by the client 102.
  • the cache function 208 of the server 206 receives the request for the content object.
  • the URI is evaluated by the protocol attribute selector 212 to find a match to something in the table 220.
  • the table 220 is queried in block 424 for any attributes. Retrieved attributes are communicated to the TCP handler 214 in block 428.
  • the connection is established in block 432 according to the selected attributes to connect the end user system 102 with the server 206.
  • the content object is delivered in block 436. This process is performed on each URI such that each connection or socket can be independently controlled, if desired. Indeed, two different end user systems 102 could request the same content object and it could be delivered in a very different manner with different selected protocol attributes for each user.
  • a content object can be either a file or a stream.
  • the content object could be a voice call stream, a video stream, an image file, a music file, a live concert, an animation, an advertisement, a web page, a slide show, data file, hosted software, transactions, executable software or the like.
  • Content can be static or dynamic, can pre-exist on the server, can be created on the server, or can be created or obtained elsewhere in response to a request from a client.

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • General Business, Economics & Management (AREA)
  • Multimedia (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer And Data Communications (AREA)

Abstract

A system for adapting the interoperation of nodes in an information processing system is disclosed. The system includes a protocol handler, a protocol attribute information store and a protocol attribute selector. The protocol handler manages a first connection and a second connection over the network using a protocol. The protocol attribute information store holds a plurality of attributes. The protocol attribute selector evaluates first information related to a first connection, utilizes the protocol attribute information store to determine first protocol attributes corresponding to the first connection, and communicates the first attributes for the first connection to the protocol handler. Additionally, the protocol attribute selector evaluates second information related to a second connection, utilizes the protocol attribute information store to determine second attributes corresponding to the second connection, and communicates the second attributes for the second connection the protocol handler. The protocol handler uses first attributes for the first connection and second attributes for the second connection.

Description

CONDITIONAL PROTOCOL CONTROL
BACKGROUND
[0001] This disclosure relates in general to interoperating nodes in an information processing system, such as an Internet content delivery system or an Internet transaction acceleration system, and, but not by way of limitation, to control of connection protocols.
[0002] In an information processing system, including communications networks such as the Internet, two or more nodes can work together, for example exchanging information or sharing resources, using one or more protocols that enable the participating nodes to interoperate. Nodes need not be physically distinct from one another, though they may be; normally, however, nodes are at least logically distinct from one another in at least some respect. Interoperating nodes may be operated or managed by a single common authority or by independent, unrelated authorities. Two or more interoperating nodes are often independently operated or managed; the Internet includes many well known examples of the interoperation of two or more independently managed nodes.
[0003] A protocol can be standardized such that a node using the standard protocol should be able to interoperate, at least at the level of the protocol, with any other node using the standard protocol. Standard protocols that become widely adopted can permit a node to interoperate with many other nodes. One such widely adopted standard protocol on the Internet is the Transmission Control Protocol (TCP), which today enables almost every device on the Internet to interoperate with almost every other device. TCP operates at the connection layer and enables nodes to interoperate with other nodes by establishing communications connections.
[0004] Standard protocols often employ the use of attributes, such as configurable parameters and selectable algorithms, to permit the protocol to operate effectively in various situations. For example, TCP controls message size, the rate at which messages are exchanged, and factors related to network congestion through the use of attributes, including both by the use of parameters, such as the receive window field used in sliding window flow control and the retransmission timer, and by the use of algorithms, such as slow-start, congestion avoidance, fast retransmit, and fast recovery algorithms. It is often the case, in many standard protocols, that at each node the initial protocol attribute settings to be used for all the communication connections at the node can be independently specified by the operator of the node. [0005] A protocol can also be customized, which in general requires that each node have installed customized components to enable the custom protocol. Without the customized components, the node would not be able to fully interoperate with other nodes using the customized protocol. Although it therefore may limit the total number of interoperable nodes, or in the alternative require widespread action to install the protocol customized components, or possibly both, protocol customization is used in order to add function, improve performance, increase flexibility, or modify other characteristics of a standard protocol, or to make available an entirely new customized protocol. Many customized protocols have been proposed for use on the Internet.
SUMMARY
[0006] In one embodiment, a system utilizing a standard protocol to enable two or more nodes to interoperate is disclosed. The protocol attributes specified in the standard protocol are conditionally adapted to the circumstances, use, and/or operating conditions of the interoperation of the nodes. In another embodiment a method is disclosed for utilizing a standard protocol to enable two or more nodes to interoperate, wherein the protocol attributes specified in the standard protocol are conditionally adapted to the circumstances, use, and/or operating conditions of the interoperation of the nodes.
[0007] In one embodiment, a system for supplying content objects over a network is disclosed. The system includes a protocol handler, a protocol attribute information store, and a protocol attribute selector. The protocol handler manages a first connection and a second connection over the network using a standard protocol. The protocol attribute information store holds a plurality of attributes defined for a plurality of connections. The protocol attribute selector receives first information based on a first request for content, identifies first attributes corresponding to the connection that will service the first request for content, provides the protocol handler with the first attributes for the connection servicing the first request for content, receives second information based on a second request for content, identifies second attributes corresponding to the connection that will service the second request for content, and provides the protocol handler with the second attributes for the connection servicing the second request for content.
[0008] In another embodiment, a network connection method for delivering content is disclosed. A first request for content is received over a network at a server. The first request for content is evaluated to select first protocol attributes. A first connection that sends the content from the server to a first node is configured according to the first protocol attributes. A second request for content is received over the network at the server. The second request for content is evaluated to select second protocol attributes. A second connection that sends the content from the server to a second node is configured according to the second protocol attributes, where the first attributes affect the operation of the protocol differently than the second attributes affect the operation of the protocol.
[0009] In another embodiment, a system for conducting transactions over a network is disclosed. The system includes a protocol handler, a protocol attribute information store, and a protocol attribute selector. The protocol handler manages a first connection and a second connection over the network using a standard protocol. The protocol attribute information store holds a plurality of attributes defined for a plurality of connections. The protocol attribute selector receives first information based on a first transaction, identifies first attributes corresponding to the connection that will service the first transaction, provides the protocol handler with the first attributes for the connection servicing the first transaction, receives second information based on a second transaction, identifies second attributes corresponding to the connection that will service the second transaction, and provides the protocol handler with the second attributes for the connection servicing the second transaction.
[0010] In another embodiment, a network connection method for conducting transactions over a network is disclosed. A first transaction is initiated over a network at a server. The first transaction is evaluated to select first protocol attributes. A first connection, servicing the first transaction, between the server and a first node is configured according to the first protocol attributes. A second transaction is initiated over the network at the server. The second transaction is evaluated to select second protocol attributes. A second connection, servicing the second transaction, between the server and a second node is configured according to the second protocol attributes, where the first attributes affect the operation of the protocol differently than the second attributes affect the operation of the protocol.
[0011] Further areas of applicability of the present disclosure will become apparent from the detailed description provided hereinafter. It should be understood that the detailed description and specific examples, while indicating various embodiments, are intended for purposes of illustration only and are not intended to necessarily limit the scope of the disclosure. BRIEF DESCRIPTION OF THE DRAWINGS [0012] The present disclosure is described in conjunction with the appended figures:
FIG. 1 depicts a block diagram of an embodiment of a content delivery system;
FIGs. 2A, 2B, 2C, and 2D depict block diagrams of embodiments of a content download pair that sends content from a server to a client;
FIG. 3 illustrates a flowchart of an embodiment of a process for modification of the TCP protocol for various connections to a server; and
FIG. 4 illustrates a flowchart of an embodiment of a process for modifying protocol attributes potentially on a connection-by-connection basis is shown.
[0013] In the appended figures, similar components and/or features may have the same reference label. Further, various components of the same type may be distinguished by following the reference label by a dash and a second label that distinguishes among the similar components. If only the first reference label is used in the specification, the description is applicable to any one of the similar components having the same first reference label irrespective of the second reference label.
DETAILED DESCRIPTION
[0014] The ensuing description provides preferred exemplary embodiment(s) only, and is not intended to limit the scope, applicability or configuration of the disclosure. Rather, the ensuing description of the preferred exemplary embodiment(s) will provide those skilled in the art with an enabling description for implementing a preferred exemplary embodiment. It being understood that various changes may be made in the function and arrangement of elements without departing from the spirit and scope as set forth in the appended claims.
[0015] Referring first to FIG. 1, a block diagram of an embodiment of an Internet content delivery system 100 is shown. Generally, one or more nodes request content from one or more other nodes. In FIG. 1, a number of end users 108 respectively use their end user system or client 102 to download and view content objects from the global Internet 104. The content delivery system 110 has one or more servers that provide content object downloads. The content delivery system 110 can include any number of cache servers, application servers, content servers, service servers, and/or database servers to provide content to the clients 102. Although this embodiment shows particular communication pairs, other embodiments could communicate between any pair of nodes on a network, including between pairs of clients or between pairs of servers, and yet other embodiments could communicate among more than two nodes, such as in a broadcast or multicast implementation.
[0016] With reference to FIGs. 2A, 2B, 2C and 2D, embodiments of a content download pair 200 that sends content from a server 206 to a client 102. A primary embodiment described here is the interoperation of two nodes 102, 206 on the Internet communicating using TCP, one node being a client 102 that requests information, such as web page content, multimedia, or software downloads, and the second node being a server 206 that provides information in response to a request. TCP operates in the transport layer of the seven-layer Open Systems Interconnection (OSI) model. In other embodiments, nodes 102, 206 interoperate in ways other than communication in a network, such as sharing data within a computer or group of computers across an available system or intersystem interface; interoperate using communications networks other than the Internet 104, such as a private communications network; interoperate using the Internet 104 or a private network using protocols other than TCP, such as UDP, RTP, multicast protocols, and other standard protocols in the transport layer; interoperate using the Internet 104 or a private network using standard protocols operating in a layer that underlies the transport layer; interoperate, using standard protocols and the Internet or a private network, more than two at a time, such as in clusters or multicast groups; or interoperate, using standard protocols and the Internet or a private network, other than as a client and server, including interoperating as peers, as collaborative nodes, or as a group of nodes under the common control of one or more other nodes or under the common control of a controller.
[0017] In the primary embodiment, the server 206 conditionally adapts the attributes of the TCP protocol for each TCP connection established by a client 102. Conditionally adapting the attributes of the TCP protocol does not require changes to standard TCP protocol implementations at every node, does not require special components be installed in the TCP protocol implementation at every node, and therefore does not comprise implementing a customized protocol as previously described; rather, the primary embodiment utilizes the standard TCP protocol and the attributes implemented in it. In other embodiments, the server conditionally adapts the attributes of other transport-layer protocols for each session established by a client 102; the server conditionally adapts the attributes of other protocols that underlie the transport layer for each session established by a client 102; the server 206 conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions established by clients 102; the server 206 conditionally adapts the attributes of the TCP protocol or other protocol for connections or sessions established by groups or subsets of groups of clients 102; the client 102 conditionally adapts the attributes of the TCP protocol for each TCP connection established; the client 102 conditionally adapts the attributes of other protocols for each session established; the client 102 conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions; a node conditionally adapts the attributes of the TCP protocol or other protocol for each connection or session; a node conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions; a node conditionally adapts the attributes of the TCP protocol or other protocol for connections or sessions established by groups or subsets of groups of nodes; a controller conditionally adapts the attributes of the TCP protocol or other protocol for each connection or session of at least one node of an interoperating group of nodes; a controller conditionally adapts the attributes of the TCP protocol or other protocol for groups of connections or sessions of at least some nodes of an interoperating group of nodes; or, a controller conditionally adapts the attributes of the TCP protocol or other protocol for connections or sessions established by groups or subsets of groups of nodes.
[0018] Software, software modifications, or equivalent function, may optionally be implemented at a server, client, or node that sets the conditionally adapted protocol attributes of a connection or session, but need not be implemented at servers, clients, or nodes that passively participate in a conditionally adapted protocol connection or session. Such software, software modifications, or equivalent function will only be needed if existing protocol software or other software on the server, client, or node does not provide a facility for programmatically or similarly changing attributes of the protocol that is used; in this event, software, a software modification, or equivalent facilities to provide such a programmatic or similar interface may be implemented.
[0019] Conditionally adapting the protocol for each connection or session, or collection of connections or sessions, results in at least one node that, concurrently or over time, uses a protocol for multiple unrelated connections or sessions wherein the protocol attributes vary, at least initially and sometimes persistently, from one connection or session to another, most often varying differently from any ordinary protocol attribute variations that naturally occur from one connection or session to another through use of the standard protocol implementation among heterogeneous nodes.
[0020] In the primary embodiment, TCP connections are established in order to use HyperText Transfer Protocol (HTTP) to communicate information requests from clients 102 to servers 206 and responses from servers 206 to clients 102. HTTP is a scheme that operates above, and depends on the presence of a functioning and reliable protocol at, the transport layer of the seven-layer model developed in the Open Systems Interconnection (OSI) initiative. Other embodiments use application-layer protocols other than HTTP in conjunction with TCP; use TCP alone, i.e., without HTTP; use other protocols; or, use other application-layer protocols in conjunction with other protocols. HTTP utilizes Uniform Resource Locators (URLs), Uniform Resource Names (URNs), and Uniform Resource Identifiers (URIs) to identify information. URLs are used in the primary embodiment. Other embodiments use URIs, URNs, other identifiers, or other information. A URL begins with the scheme identifier, which identifies the namespace, purpose, and syntax of the remainder of the URL. In the primary embodiment utilizing HTTP, the typical scheme is "http". The scheme is followed by a host field, which contains the IP address or name of the host where the requested information can be found, optionally followed by a port number, optionally followed by a path, which is an HTTP selector, optionally followed by a search portion, which is a query string. The full URL, then, is an alphanumeric string containing the scheme, host field, any optional following strings, and special characters such as ":", "/", and "?" that are reserved for special functions such as designating a hierarchical structure in the URL. Other embodiments could use different application-layer protocols such as Telnet, File Transfer Protocol (FTP), secure HTTP (HTTPS), and Simple Mail Transfer Protocol (SMTP).
[0021] In the primary embodiment, the server 206 bases the conditional adaptation of the attributes of the TCP protocol on the alphanumeric URL string provided by the client 102 in its information request. In another embodiment, a server, client or other node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on the application-layer protocol specified or on identifying information, equivalent to a URL, or other information provided in, or characteristic of, an information request, connection, or session. In other embodiments, a server, client or other node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on the IP address of one or more servers, clients, or nodes; on network information associated with the IP address of one or more servers, clients, or nodes, including the Autonomous System (AS) number, identity of network operator, geographic location, logical or physical network location, logical or physical network segment, or network interconnection characteristics associated with the IP address(es) of one or more servers, clients, or nodes; the geographic location of the server, client or node; and/or, the logical or physical network location of the server, client or node; the logical or physical address of the server, client or node; the logical or physical name of the server, client or node; and/or, the network or other path from or to a server, client or node. In other embodiments a server, client or node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on recent network performance measurements, including latency, jitter, packet loss, round trip time, and/or the measured variance in a network performance measurement across multiple samples; on recent measures of utilization of a network, network segment, network interface, or network port; and/or, on recent measurements of performance or utilization of a server, group of servers, or server component(s) such as memory, processor, disk, bus, intersystem interface, and/or network interface. In still other embodiments, a server, client or node bases the conditional adaptation of the attributes of the TCP protocol or other protocol on temporal factors, including time of day; day of week, month, or year; specific date; occurrence of a holiday or religious observance; occurrence of a temporal event such as a news event or sports event; seasonal occurrence; and/or a scheduled event or time period.
[0022] In the primary embodiment, the protocol attribute selector 212 of the server 206 compares the alphanumeric URL string provided by the client 102 in its information request to a table 220 containing partial or whole URLs and identifies the most specific match from left to right that it can find in the table 220. In another embodiment, the server 206 compares a subset of the alphanumeric string, for example some or all of the characters in the query string, or the characters following the host field up to the first subsequent slash (i.e., "/"), to a table 220. In another embodiment, the client or node 102 makes a conditional adaptation of protocol attributes, using the alphanumeric URL string or a subset of it. In other embodiments, the alphanumeric URL string or a subset of it is processed to obtain a value or indicator that is used to determine a conditional adaptation of protocol attributes. In other embodiments, the information used to determine the conditional adaptation of protocol attributes is identifying information equivalent to a URL, one or more IP addresses, network information associated with one or more IP addresses, network interconnection characteristics associated with one or more IP addresses, or the geographic location, or logical or physical network location, of a server, client or node. In other embodiments, the information used to determine the conditional adaptation of protocol attributes comprises one or more recent performance measurements or thresholds related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components, or network interfaces; rates or amounts of variation in one or more performance measurements or thresholds related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components or network interfaces; rates or amounts of resource utilization, including utilization related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or components of one or more servers, clients, or nodes, groups of components of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components, or network interfaces; rates or amounts of variation in resource utilization, including variation in utilization related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or components of one or more servers, clients, or nodes, groups of components of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components, or network interfaces; and/or, thresholds of resource utilization, including utilization related to one or more servers, clients, or nodes, or groups of servers, clients, or nodes, or components of one or more servers, clients, or nodes, groups of components of servers, clients, or nodes, or related to one or more networks, network segments, network components, or network interfaces, or groups of network segments, network components, or network interfaces.
[0023] In the primary embodiment, a table 220 containing partial or whole URLs for comparison by the protocol attribute selector 212 is stored on the server 206. In other embodiments, a table 220 containing partial or whole URLs for comparison, or subsets of the alphanumeric URL string used for comparison, is stored remotely from the server 206 such as the embodiment shown in FIG. 2B and the comparison of the alphanumeric URL string or subset of the alphanumeric URL string is made at the server 206, or is made at the remote table storage location or at another location and the result of the comparison, or an indicator of the result of the comparison, or the protocol attributes to be used, are returned to the server 206. In other embodiments, a table 220 or database of information used for comparison is stored at the server 206, or is stored remotely from the server 206 and one or more comparisons are made at the server 206, or are made at the remote storage location or at another location, and the results of the comparisons, or one or more indicators of the results of the comparisons, or the protocol attributes to be used, are returned to the server 206. In yet other embodiments, a table 220 containing partial or whole URLs for comparison, or subsets of the alphanumeric URL string used for comparison, or a database of information used for comparison is stored at a client or node 102 as is shown in FIG. 2D, or is stored remotely from a client or node and one or more comparisons are made at the client or node 102, or are made at the remote storage location or at another location and the results of the comparisons, or one or more indicators of the results of the comparisons, or the protocol attributes to be used, are returned to the client or node 102. In other embodiments, a protocol attribute to be used, or an indicator of a protocol attribute to be used, is extracted from, or derived from, a URL or equivalent identifying information used by a server, client, or node; is extracted from, or derived from, address information or a whole or partial name of a server, client, or node; is extracted from, or derived from a user name or identifier, class or type of user, group of users, or selection of users, optionally as associated with a service, server, client, or node; is extracted from, derived from, or associated with, an application or class or group of applications, a service or class or group of services, or a database or equivalent source of data or a class or group of databases or sources of data; is extracted from, or derived from, the identifier of a standard protocol, a standard protocol message (for example, a TCP SYN), the protocol-level content of a message, or protocol message headers or equivalent information; is derived from all or a part of the time, all or a part of the date, or all or a part of the duration since a time or date; is determined according to a sequence or progression; and/or, is determined randomly or pseudo-randomly.
[0024] After one or more comparisons are made, or after the extraction or derivation of a value, or after an association or determination is made, the server, client, or node will have one or more values it can use as protocol attributes or as indicators of which protocol attributes to use; or, if there has not been a determination of a condition resulting in one or more protocol attribute values to use, then in the primary embodiment the server 206 will use the standard values for the protocol attributes as configured for the server 206, and in other embodiments, the server, client, or node will use the standard values as configured for it for some or all of the protocol attributes; the server, client, or node will use another default value for some or all of the attributes; the server, client, or node will use the last- used values for some or all of the attributes; or, the server, client, or node will use randomly, pseudo-randomly, or arbitrarily determined values for some or all of the attributes.
[0025] In the primary embodiment, the server 206 is a cache server, typically operating in a group of cache servers, and groups of cache servers are distributed at numerous points on the global Internet. The server 206 includes a cache function 208 coupled to a content cache 210 to provide caching of content for the server 206. In another embodiment, the server 206 is a cache server operating individually, or independently from other cache servers. In other embodiments, the server 206 is a content server that provides content; a content server operating in a group of content servers; a content server operating in a group of content servers distributed at numerous points on the global Internet; an application server that supports one or more applications; an application server operating in a group of application servers; an application server operating in a group of application servers distributed at numerous points on the global Internet; a service server that provides one or more services; a service server operating in a group of service servers; a service server operating in a group of service servers distributed at numerous points on the global Internet; a database server that provides data; a database server operating in a group of database servers; a database server operating in a group of database servers distributed at numerous points on the global Internet; a server operating in a heterogeneous group of servers; or, a server operating in a heterogeneous group of servers distributed at numerous points on the global Internet.
[0026] In the primary embodiment, each server 206 has an identical copy of a table 220 containing partial or whole URLs to which the alphanumeric URL string provided by the client 102 in its information request will be matched if possible, along with an indicator of the protocol attribute values to be used when that match occurs or the actual protocol attribute values themselves to be used when that match occurs. The table 220 can be modified from time to time, including adding new entries, changing the contents of existing entries, and deleting entries. Any time that a new version of the table 220 is created, copies of that version are distributed to servers 206 in the global group of cache servers. Optionally, the table 220 can have an expiration date and time, after which the server 206 will stop using the table 220 if it is out-of-date and has not been replaced with an updated table. In the primary embodiment, the conditional protocol control information is combined with other information distributed to servers 206 so as to minimize to the extent practicable the number of tables 220 that are distributed to, and synchronized among, the global group of servers; in another embodiment, this combination and minimization is not implemented; and this combination and minimization is not done in most or all other embodiments.
[0027] In other embodiments, the conditional protocol information may be in the form of a table 220 as in the primary embodiment, or may be in the form of multiple tables, or may be in the form of one or more data files, one or more databases, one or more calculated or derived elements, one or more calculated or derived groups of elements, one or more individual equations or formulas, one or more groups of equations or formulas, one or more individual expressions, one or more groups of expressions, one or more individual programs or routines, one or more groups of programs or routines, one or more individual listings, one or more groups of listings, and/or other forms equivalent to any of these.
[0028] In other embodiments, the conditional protocol control information contains partial or whole URLs to which the alphanumeric URL string provided by the client 102 in its information request will be matched if possible, along with an indicator of the protocol attribute values to be used when that match occurs or the actual protocol attribute values themselves to be used when that match occurs, and is the same for each server 206 at a location, but varies from one location to another; is the same for each server in a region, but varies from one region to another; or, is different at each server. In other embodiments the conditional protocol control information contains partial or whole URLs to which the alphanumeric URL string used by a client or node 102 will be matched if possible, along with an indicator of the protocol attribute values to be used when that match occurs or the actual protocol attribute values themselves to be used when that match occurs, and the conditional protocol control information is identical at each client or node 102; is the same for each client or node 102 in a group, but varies from one group of clients or nodes 102 to another; is the same for each client or node 102 in a region, but varies from one region to another; or, varies from one client or node 102 to another client or node 102.
[0029] In other embodiments, the conditional protocol control information contains other comparison information that will be matched, if possible, along with a corresponding indicator of the protocol attribute values to be used when that match occurs or the corresponding actual protocol attribute values themselves to be used when that match occurs, and each server, client, or node has an identical copy of the conditional protocol control information; the conditional protocol control information is the same for each server, client, or node at a location, but varies from one location to another; the conditional protocol control information is the same for each server, client, or node in a region, but varies from one region to another; the conditional protocol control information is the same for each server, client, or node in a group, but varies from one group to another; or, the conditional protocol control information varies from one server, client, or node to another. In these embodiments, the comparison information can include subsets of the alphanumeric URL string; identifying information equivalent to a URL; one or more IP addresses; network information associated with one or more IP addresses; network interconnection characteristics associated with one or more IP addresses; the geographic location, or logical or physical network location, of a server, client, or node; a value of a performance measurement or threshold; a rate or amount of variation in a performance measurement or threshold; a rate or amount of resource utilization; a rate or amount of variation in resource utilization; a threshold of resource utilization; addresses, names, classes, types, or group identifiers of servers, clients, nodes, users, applications, services, databases, or other data sources; protocol identifiers, protocol message identifiers or attributes, or protocol message headers or attributes; times, dates, or intervals; and/or, sequences, ratios, progressions, equations, randomly generated data, or arbitrarily determined data.
[0030] In embodiments where the conditional protocol control information is not identical at all servers, clients, or nodes, optionally a system can create conditional protocol control information for each location, region, server, client, or node, and optionally can manage the distribution of the conditional protocol control information to each location, region, server, client, or node. For partial or whole URLs, subsets of a URL alphanumeric string, or other comparison information that will be compared, a conditional protocol information management and distribution system (CPIMDS) optionally generates, or stores, or generates and stores, protocol attributes for any or all of a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, an application, all applications, a subset of applications, a service, all services, a subset of services, a database or data source, all databases or data sources, a subset of databases or data sources, a protocol, all protocols, a subset of protocols, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some, a subset of, a subset of some of, or all of, servers, locations, regions, groups, applications, services, databases or data sources, protocols, clients, or nodes; and optionally generates, or stores, or generates and stores, default protocol attributes to be used in the absence of a matching comparison for any or all of a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, an application, all applications, a subset of applications, a service, all services, a subset of services, a database or data source, all databases or data sources, a subset of databases or data sources, a protocol, all protocols, a subset of protocols, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some, a subset of, a subset of some of, or all of, servers, locations, regions, groups, applications, services, databases or data sources, protocols, clients, or nodes. The CPIMDS also optionally generates, or stores, or generates and stores, one or more rules for determining which of the server, location, region, group, application, service, database or data source, protocol, client, node, or combined values to use when determining a comparison to be included in the conditional protocol control information for a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, an application, all applications, a subset of applications, a service, all services, a subset of services, a database or data source, all databases or data sources, a subset of databases or data sources, a protocol, all protocols, a subset of protocols, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some, a subset of, a subset of some of, or all of, servers, locations, regions, groups, applications, services, databases or data sources, protocols, clients, or nodes; optionally generates, or stores, or generates and stores, one or more rules for determining when to create, or distribute, or create and distribute, conditional protocol control information for or to a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some or all of servers, locations, regions, groups, clients, nodes, or a subset of servers, locations, regions, groups, clients, nodes, or for or to all servers, clients, or nodes; optionally generates, or stores, or generates and stores, one or more rules for determining whether, and if so when, any conditional protocol control information shall expire; optionally includes an expiration value with some or all of the conditional protocol control information; and, optionally distributes conditional protocol control information to a server, all servers, a subset of servers, a location, all locations, a subset of locations, a region, all regions, a subset of regions, a group, all groups, a subset of groups, a client, all clients, a subset of clients, a node, all nodes, a subset of nodes, or a combination of some or all of servers, locations, regions, groups, clients, nodes, or a subset of servers, locations, regions, groups, clients, nodes, or for or to all servers, clients, or nodes.
[0031] In embodiments where the conditional protocol control information is maintained separately from each server, client, or node, the conditional protocol control information can optionally include, or can optionally correlate to, an indication of for which servers, locations, regions, groups, applications, services, databases or data sources, protocols, clients, nodes, or supersets, subsets, or combinations thereof, the conditional protocol control information can be used in adapting protocol attributes. The conditional protocol control information can be maintained at a single location or multiple locations; if maintained at multiple locations, each location can maintain a complete copy of all conditional protocol control information, or each location can maintain a copy of a subset of the conditional protocol control information. Optionally, a conditional protocol information management and distribution system can create conditional protocol control information for, and optionally distribute conditional protocol control information to, each conditional protocol control information location, groups of conditional protocol control information locations, or all conditional protocol control information locations. If conditional protocol control information locations store a subset of the conditional protocol control information, participating servers, clients, or nodes can optionally use a table, ordered table, shuffled table, directory, logical name translation system, or information obtained from, or received from, another server, client, node, or controller, to determine which conditional protocol control information location to receive conditional protocol control information from.
[0032] Referring next to FIG. 3, an embodiment of a process 300 for modification of the TCP protocol for various connections to a server 206. In summary, in the primary embodiment two nodes on the Internet communicate using TCP, one node being a client 102 that requests information in block 304, such as web page content, and the second node being a cache server 206 that provides information in response to a request. The cache server 206 operates as one of a group of cache servers, and groups of cache servers are distributed at numerous points on the global Internet. TCP connections are established in order to use HTTP to communicate information requests from clients 102 to servers 206 in block 304 and responses from servers 206 to clients 102. HTTP utilizes URLs; each URL begins with the scheme "http", which is followed by a host field containing the IP address or name of the host where the requested information can be found, followed by a path, which will be used at the server 206 to locate the requested object or information, optionally followed by a query string. Thus, the full URL typically is an alphanumeric string containing the scheme, host field, path, and any optional query string, each part of which is separated from the other parts by special characters such as ":", "/", and "?". Thus, an example URL referencing content that can be served by the cache server 206 in the primary embodiment might look like:
http://customerl.webserving.com/folderB/directory/logo.gif
optionally followed by "?" and a query string. A client 102 requesting this object would send an HTTP message using an HTTP method called "GET" to the server 206 identified by the hostname "customerl .webserving.com" in block 304. The server identification is accomplished through a DNS translation of the hostname into one or more IP addresses. The Domain Name System (DNS) is the name translation system used in the Internet. The HTTP GET message sent to the server 206 typically includes part or all of the URL that the client 102 is requesting. In block 308, some or all of the URL is compared with entries in the table 220 to determine the attributes to use for the connection as described further below.
[0033] In the primary embodiment, in block 312 the server 206 conditionally adapts the attributes of the TCP protocol for each TCP connection established by a client 102. Conditionally adapting the attributes of the TCP protocol does not require changes to standard TCP protocol implementations at every node, i.e., any client 102 that supports standard TCP (which virtually all Internet and all World Wide Web clients do) can communicate with the server 206 to get the object via a conditionally adapted TCP connection, but may require a modification to the server's TCP protocol handler to allow changes to be made to the TCP protocol attributes by another program, or on a per- connection basis, or both. Where the TCP protocol handler provides a facility for programmatically making these changes, the content serving application may require an interface enabling it to communicate conditionally adapted TCP protocol attributes to the TCP protocol handler. In our implementation of the primary embodiment, we use a "set sockets" statement to communicate conditionally adapted TCP protocol attributes from the content serving application to the TCP handler 214, which is a modified TCP software stack that can accept and implement changes to the TCP protocol attributes on a per-connection basis. In various embodiments, the TCP handler could be implemented in software or hardware or both, and can be implemented as part of a node or separately from the node, for example in a switch or other device that provides protocol services.
[0034] Conditionally adapting the protocol for each connection results in the server 206 concurrently using the TCP protocol for multiple unrelated connections, wherein the TCP protocol attributes vary, at least initially and sometimes persistently, from one connection to another. At block 316, the requested object or information is sent from the server 206 to the client 102. When a requested object or information is delivered without any change to the TCP protocol attributes, the standard TCP protocol attributes pre-configured for the TCP protocol handler are used; but when the requested object or information is delivered with conditionally adapted TCP protocol attributes, the conditionally determined TCP protocol attributes are used instead of the standard pre-configured TCP attributes.
[0035] A typical caching content server 206 in actual operating use in a web hosting service provider environment may typically service 2,000 to 3,000 requests per second, across 100 to 200 (or more) customers. If half of these requests will use changed TCP protocol attributes and half will not, then on average, half of the connections managed by the server 206 at any one point in time would use the changed TCP protocol attributes and half would use the standard TCP protocol attributes as pre-configured in the TCP handler 214. Additionally, if there are five separate (different) changed TCP protocol attribute sets across which those requests using changed TCP protocol attributes are evenly distributed, then on average at any one point in time a server 206 would concurrently be operating TCP connections with six different sets of TCP protocol attributes: 50% of the connections would utilize standard pre-configured TCP protocol attributes, and 10% would utilize each of the five possible changed TCP protocol attribute sets.
[0036] In the primary embodiment, the server 206 bases the conditional adaptation of the attributes of the TCP protocol on the alphanumeric URL string provided by the client 102 in the HTTP GET message. In the primary embodiment, the conditional protocol control information is in the form of a table 220 containing partial and/or whole URLs for comparison, the table 220 is stored on the server 206, and the table 220 is generally kept reconciled on all servers 206. The server 206 compares the alphanumeric URL string provided by the client 102 in the GET request to the table 220 and identifies the most specific match from left to right that it can find in the table 220 in block 308. Taking our earlier example and assuming a simplified table, the sole Table shows mappings from whole and/or partial URLs into TCP attribute sets comprising specific protocols attributes (identified as "attrl", "attr2", "attr3", etc.) to be used and the appropriate value or setting for that use of that attribute.
Table Mapping to TCP attribute sets
Partial URL TCP Attribute Set http://customerl.webserving.com/folderA7 attrl=yes, attr3=25, attr4=low http://customerl.webserving.com/folderB/ attrl=no, attr2=l, attr4=high fastnet.com attr3=5O, attr6=fast http : //customer2. webserving. com/ http://customer3.webserving.com/ attrl=yes, attr3=25, attr4=low
The URL in the example above,
"http://customerl .webserving.com/folderB/directory/logo.gif," would be matched against the second line-entry in the table. The TCP protocol attribute set (group of TCP protocol attributes) to be used for the TCP connection that services, or responds to, this HTTP GET message from this client 102 would be "attrl =no, attr2=l, attr4=high" and the TCP protocol attributes for this TCP connection would be set accordingly. This simplified table example also illustrates that the scheme and host name may be sufficient for a matching entry, such as in the case of the entry "http://customer3.webserving.com," or the host name alone may be sufficient, such as in the case of the entry "fastnet.com." This simplified table example also illustrates that there may be a null entry in the table, as in the case of "http://customer2.webserving.com"; in this simplified table example, the null entry signifies use of the standard pre-configured TCP protocol attributes. Note that an actual table in the primary embodiment would contain more information than the simplified example table shown here, as discussed.
[0037] The table 220 can be modified from time to time, including adding new entries, changing the contents of existing entries, and deleting entries. When a new version of the table 220 is created, copies of the new version of the table 220 are distributed to the servers 206 in the global group of cache servers. Optionally, the table 220 can have an expiration date and time, after which the server 206 will stop using the table 220 if it is out-of-date and has not been replaced with an updated table 220; under this condition, the server 206 would then use the standard TCP protocol attributes for connections until the server 206 received an updated or unexpired table 220.
[0038] In the primary embodiment, the conditional protocol control information is combined with other information, such as customer billing codes and other customer- specific information, that is distributed to all servers 206, in order to minimize the number of tables that are distributed to, and reconciled throughout, the global group of servers. This embodiment has the advantage of simplifying administration, change management, and rollback in the event that distribution of a new table 220 causes a problem or error condition, but the disadvantage that the conditional protocol adaptation is the same for any given entry in the table 220 at every server 206, regardless of the server's location or other factors. In other embodiments, as discussed, the conditional protocol control information can vary from one server 206 to another.
[0039] Referring to FIG. 4, an embodiment of a process for potentially modifying protocol attributes on a connection-by-connection basis is shown. The depicted portion of the process begins in block 416 where a uniform resource indicator (URI) is requested by the client 102. The cache function 208 of the server 206 receives the request for the content object. The URI is evaluated by the protocol attribute selector 212 to find a match to something in the table 220. The table 220 is queried in block 424 for any attributes. Retrieved attributes are communicated to the TCP handler 214 in block 428. The connection is established in block 432 according to the selected attributes to connect the end user system 102 with the server 206. The content object is delivered in block 436. This process is performed on each URI such that each connection or socket can be independently controlled, if desired. Indeed, two different end user systems 102 could request the same content object and it could be delivered in a very different manner with different selected protocol attributes for each user.
[0040] Throughout this document, the terms content delivery and content download are used and can mean either file download or streaming delivery. Additionally, a content object can be either a file or a stream. For example, the content object could be a voice call stream, a video stream, an image file, a music file, a live concert, an animation, an advertisement, a web page, a slide show, data file, hosted software, transactions, executable software or the like. Content can be static or dynamic, can pre-exist on the server, can be created on the server, or can be created or obtained elsewhere in response to a request from a client.
[0041] A number of variations and modifications of the disclosed embodiments can also be used. For example, some of the above embodiments discuss use of the TCP protocol or a transport-layer protocol. Other protocols could be modified on a connection-by-connection basis in other embodiments.
[0042] While the principles of the disclosure have been described above in connection with specific apparatuses and methods, it is to be clearly understood that this description is made only by way of example and not as limitation on the scope of the disclosure.

Claims

CLAIMS WHAT IS CLAIMED IS:
1. A network connection method for delivering content, the network connection method comprising: receiving a first request for content from a network at a server; analyzing the first request for content to determine first attributes; configuring a first connection for serving the content between the server and a first node; configuring a protocol of the first connection according to the first attributes, wherein the protocol that is configured is a transport layer protocol or operates at a layer below the transport layer; receiving a second request for content from the network at the server; analyzing the second request for content to determine second attributes; configuring a second connection for serving the content between the server and a second node; and configuring the protocol of the second connection according to the second attributes, wherein the first attributes affect operation of the protocol differently than the second attributes affect operation of the protocol.
2. The network connection method for delivering content as recited in claim 1 , wherein the protocol operates in a transport layer.
3. The network connection method for delivering content as recited in claim 1, wherein analyzing the first request comprises comparing a first uniform resource indicator (URI) with alphanumeric strings to correlate the first URI with the first attributes.
4. The network connection method for delivering content as recited in claim 1, wherein the protocol is transmission control protocol (TCP).
5. The network connection method for delivering content as recited in claim 1, wherein the analyzing limitations are performed away from the server.
6. The network connection method for delivering content as recited in claim 1 , wherein the first connection and second connection serve the content at least partially coextensive in time.
7. The network connection method for delivering content as recited in claim 1 , wherein the content in the first-listed analyzing limitation is different from the content in the second-listed analyzing limitation.
8. A system for managing delivery of content over a network, the system comprising: protocol handler managing a first connection and a second connection over the network using a protocol, wherein: the protocol operates at an transport layer or below, the protocol handler is configured to use first attributes for the first connection, and the protocol handler is configured to use second attributes for the second connection; a store holding a plurality of attributes; and a protocol attribute selector, configured to: receive first information relating to a first request for content, query the store for first attributes corresponding to the first information, program the protocol handler with the first attributes for the first connection, receive second information relating to a second request for content, query the store for second attributes corresponding to the second information, and program the protocol handler with the second attributes for the second connection.
9. The system for managing delivery of content over the network as recited in claim 8, wherein the protocol operates in a transport layer.
10. The system for managing delivery of content over the network as recited in claim 8, wherein the first information is derived from first uniform resource indicator (URI) associated with the first request for content.
11. The system for managing delivery of content over the network as recited in claim 8, wherein the protocol is transmission control protocol (TCP).
12. The system for managing delivery of content over the network as recited in claim 8, further comprising a protocol stack that sends the content to a first node using the first connection and a second node using the second connection.
13. The system for managing delivery of content over the network as recited in claim 8, wherein: the protocol handler is part of a server, and at least one of the store and the protocol attribute selector is located away from the server.
14. The system for managing delivery of content over the network as recited in claim 8, wherein the first connection and second connection serve the content at least partially coextensive in time.
15. The system for managing delivery of content over the network as recited in claim 8, wherein the content of the first connection is different from the content in the second connection.
16. A system for delivering content on a network, the system comprising: means for receiving a first request for content from the network at a server; means for analyzing the first request for content to determine first attributes; means for configuring a first connection for serving the content between the server and a first node; means for configuring a protocol of the first connection according to the first attributes, wherein the protocol that is configured is a transport layer protocol or operates a layer below the transport layer; means for receiving a second request for content from the network at the server; means for analyzing the second request for content to determine second attributes; means for configuring a second connection for serving the content between the server and a second node; and means for configuring the protocol of the second connection according to the second attributes, wherein the first attributes affect operation of the protocol differently than the second attributes affect operation of the protocol.
17. The system for delivering content on the network as recited in claim 16, wherein the protocol operates in a transport layer.
18. The system for delivering content on the network as recited in claim 16, wherein means for analyzing the first request comprises means for comparing a first uniform resource indicator (URI) with alphanumeric strings to correlate the first URI with the first attributes.
19. The system for delivering content on the network as recited in claim 16, wherein the protocol is transmission control protocol (TCP).
PCT/US2009/038361 2005-08-01 2009-03-26 Conditional protocol control WO2010110794A1 (en)

Priority Applications (6)

Application Number Priority Date Filing Date Title
PCT/US2009/038361 WO2010110794A1 (en) 2009-03-26 2009-03-26 Conditional protocol control
US12/572,981 US8274909B2 (en) 2009-03-26 2009-10-02 Conditional protocol control
US12/625,436 US7715324B1 (en) 2009-03-26 2009-11-24 Conditional protocol control
US13/595,904 US8750155B2 (en) 2009-03-26 2012-08-27 Conditional protocol control
US14/300,076 US9100463B2 (en) 2005-08-01 2014-06-09 Origin request with peer fulfillment
US14/754,453 US20160156741A1 (en) 2005-08-01 2015-06-29 Origin request with peer fulfillment

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/US2009/038361 WO2010110794A1 (en) 2009-03-26 2009-03-26 Conditional protocol control

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US12/572,981 Continuation-In-Part US8274909B2 (en) 2005-08-01 2009-10-02 Conditional protocol control

Publications (1)

Publication Number Publication Date
WO2010110794A1 true WO2010110794A1 (en) 2010-09-30

Family

ID=42781295

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2009/038361 WO2010110794A1 (en) 2005-08-01 2009-03-26 Conditional protocol control

Country Status (1)

Country Link
WO (1) WO2010110794A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8721649B2 (en) 2009-12-04 2014-05-13 Pivot Medical, Inc. Hip joint access using a circumferential wire and balloon

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060272012A1 (en) * 2005-05-31 2006-11-30 Chao-Hung Wu Multifunction server system
US20080013454A1 (en) * 2006-04-27 2008-01-17 Futurewei Technologies, Inc. Content Aware Transport Layer Multicast
US20080132259A1 (en) * 2006-12-05 2008-06-05 Eric Vin System and method of providing access to instant messaging services via a wireless network

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060272012A1 (en) * 2005-05-31 2006-11-30 Chao-Hung Wu Multifunction server system
US20080013454A1 (en) * 2006-04-27 2008-01-17 Futurewei Technologies, Inc. Content Aware Transport Layer Multicast
US20080132259A1 (en) * 2006-12-05 2008-06-05 Eric Vin System and method of providing access to instant messaging services via a wireless network

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8721649B2 (en) 2009-12-04 2014-05-13 Pivot Medical, Inc. Hip joint access using a circumferential wire and balloon

Similar Documents

Publication Publication Date Title
US8750155B2 (en) Conditional protocol control
US7715324B1 (en) Conditional protocol control
US20230115557A1 (en) Method and System for Transmitting Data in a Computer Network
US6954456B2 (en) Method for content-aware redirection and content renaming
Zhao et al. Tapestry: A resilient global-scale overlay for service deployment
US7219153B1 (en) Methods and apparatus for distributing content
EP2279584B1 (en) System and method for distributing a map of content available at multiple receivers
Baid et al. Comparing alternative approaches for networking of named objects in the future Internet
US7953808B2 (en) Automatic notification system and process
US8386622B2 (en) Method and apparatus for facilitating communication in a content centric network
KR101420548B1 (en) Method and system for supporting the selection of communication peers in an overlay network
US20130212266A1 (en) Routing client requests
JP2007143172A (en) Unified directory and presence system for universal access to telecommunication service
US20090299937A1 (en) Method and system for detecting and managing peer-to-peer traffic over a data network
WO2013075578A1 (en) System and method for offline download of network resource file
WO2001099348A1 (en) Protocol for multicast communication
US20150074234A1 (en) Content system and method for chunk-based content delivery
Moll et al. SoK: The evolution of distributed dataset synchronization solutions in NDN
EP2707997A1 (en) Method for managing the infrastructure of a content distribution network service in an isp network and such an infrastructure
US20240015135A1 (en) Domain management and synchronization system
Jin et al. Content routing and lookup schemes using global bloom filter for content-delivery-as-a-service
WO2010110794A1 (en) Conditional protocol control
AU2009201833B1 (en) Conditional protocol control
US11095605B1 (en) Request routing utilizing encoded DNS-based messaging parameters
US20230308413A1 (en) Discovering services across networks based on a multicast domain name system protocol

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 2009201833

Country of ref document: AU

121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 09842424

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 09842424

Country of ref document: EP

Kind code of ref document: A1