CA2410866A1 - Client side deterministic routing and transparent redirection - Google Patents

Client side deterministic routing and transparent redirection Download PDF

Info

Publication number
CA2410866A1
CA2410866A1 CA002410866A CA2410866A CA2410866A1 CA 2410866 A1 CA2410866 A1 CA 2410866A1 CA 002410866 A CA002410866 A CA 002410866A CA 2410866 A CA2410866 A CA 2410866A CA 2410866 A1 CA2410866 A1 CA 2410866A1
Authority
CA
Canada
Prior art keywords
content object
client computer
content
object source
source
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
CA002410866A
Other languages
French (fr)
Other versions
CA2410866C (en
Inventor
Nathan F. Raciborski
Mark R. Thompson
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google Technology Holdings LLC
Original Assignee
Individual
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 Individual filed Critical Individual
Publication of CA2410866A1 publication Critical patent/CA2410866A1/en
Application granted granted Critical
Publication of CA2410866C publication Critical patent/CA2410866C/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/30Routing of multiclass traffic
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
    • G06Q50/10Services
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9574Browsing optimisation, e.g. caching or content distillation of access to content, e.g. by caching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • H04L61/4505Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols
    • H04L61/4511Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols using domain name system [DNS]
    • 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/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • H04L65/611Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for multicast or broadcast
    • 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/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/1008Server selection for load balancing based on parameters of servers, e.g. available memory or workload
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/101Server selection for load balancing based on network conditions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/563Data redirection of data network streams
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/567Integrating service provisioning from a plurality of service providers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/63Routing a service request depending on the request content or context
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0281Proxies
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/04Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
    • H04L63/0428Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/10015Access to distributed or replicated servers, e.g. using brokers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1029Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers using data related to the state of servers by a load balancer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/568Storing data temporarily at an intermediate stage, e.g. caching
    • H04L67/5682Policies or rules for updating, deleting or replacing the stored data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/24Negotiation of communication capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/326Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the transport layer [OSI layer 4]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Multimedia (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Tourism & Hospitality (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Health & Medical Sciences (AREA)
  • Strategic Management (AREA)
  • Primary Health Care (AREA)
  • General Business, Economics & Management (AREA)
  • Marketing (AREA)
  • Human Resources & Organizations (AREA)
  • Computer Hardware Design (AREA)
  • General Health & Medical Sciences (AREA)
  • Economics (AREA)
  • Data Mining & Analysis (AREA)
  • Information Transfer Between Computers (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

A method for promoting distribution of content from a content source to a client computer via a content distribution system. The method includes associating a content source outside of the content distribution system with a transfer node inside the content distribution system. The association betwee n the content source and the transfer node is indicated to a client computer. When the client computer receives a request for content from the content source, the request is redirected to the associated transfer node. Thus, the associated transfer node fulfills the request.

Claims (21)

1. A method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, the method comprising:
associating a first content object source with a first transfer node;
indicating the first content object source and first transfer node to the client computer;
providing a content object request to the client computer, the content object request indicating a requested content object source;~
fulfilling the content object request from the transfer node, wherein:
(1) the requested content object source is the same as the associated content object source, and (2) whereby, the content object request is fulfilled transparent to the requested content object source.
2. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, the method further comprising:
comparing the requested content object source with the associated content object source to determine if they are the same content object source.
3. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, wherein:
the fulfilling the content object request comprises a request by the transfer node to the content object source.
4. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, wherein:
the indicating the associated content object source and transfer node to the client computer comprises indicating a domain name of the content object source.
5. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, wherein:
the indicating the associated content object source and transfer node to the client computer comprises indicating,an IP address of the content object source.
6. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, wherein:
the indicating the associated content object source and transfer node to the client computer comprises indicating a directory name of the content object source.
7. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, wherein:
the indicating the associated content object source and transfer node to the client computer is done at the request of the client computer.
8. The method for promoting distribution of content objects from a content object source to a client computer via a content distribution system, according to claim 1, wherein:
the associating the content object source with a transfer node comprises maintaining a list of transfer nodes and associated content object sources.
9. A method for automatically distributing a requested content object to a client computer on a content distribution system, the method comprising:
providing a content object request to the client computer, the request identifying a requested content object source;
providing an identifier to the client computer, the identifier identifying a transfer node;
determining if the transfer node is associated with the requested content object source; and fulfilling the content object request by accessing the transfer node.
10. The method for automatically distributing a requested content object to a client computer on a content distribution system, according to claim 9, wherein the providing the identifier to the client computer further comprises:
providing a plurality of identifiers to the client computer.
11. The method for automatically distributing a requested content object to a client computer on a content distribution system, according to claim 10, wherein the plurality of identifiers comprises domain names for a plurality of content object sources.
12. The method for automatically distributing a requested content object to a client computer on a content distribution system, according to claim 10, wherein the plurality of identifiers comprises IP addresses for a plurality of content object sources.
13. A method for automatically distributing a requested content object to a client computer on a content distribution system, according to claim 10, wherein the plurality of identifiers comprises domain names for a plurality of content object sources.
14. The method for automatically distributing a requested content object to a client computer on a content distribution system, according to claim 10, wherein:
the determining if the transfer node is associated with the content object source is done by examining the plurality of identifiers to determine if one of the plurality of identifiers matches the requested content object source;
15. A method for accessing a content object by a client computer from a content object source transparent to the content object source, the method comprising:
receiving a content object request, the content object request identifying a requested content object source;
providing an identifier to the client computer, the identifier identifying a transfer node and an associated content object source;
comparing the associated content object source to the requested content object source; and fulfilling the content object request by accessing the transfer node.
16. The method for accessing a content object by a client computer from a content object source transparent to the content object source, according to claim 15, wherein the providing an identifier to the client computer is done at the request of the client computer.
17. The method for accessing a content object by a client computer from a content object source transparent to the content object source, according to claim 16, wherein the fulfilling the content object request comprises a request by the transfer node to the requested content object source.
18. The method for accessing a content object by a client computer from a content object source transparent to the content object source, according to claim 17, wherein the providing an identifier to the client computer comprises providing a domain name of the associated content object source.
19. The method for accessing a content object by a client computer from a content object source transparent to the content object source, according to claim 17, wherein the transfer node stores a content object.
20. The method for accessing a content object by a client computer from a content object source transparent to the content object source, according to claim 17, wherein the providing an identifier to the client comprises providing a directory name of the associated content object source.
21. The method for accessing a content object by a client computer from a content object source transparent to the content object source, according to claim 17, wherein the providing an identifier to the client computer comprises providing an IP
address of the associated content object source.
CA2410866A 2000-06-01 2001-06-01 Client side deterministic routing and transparent redirection Expired - Fee Related CA2410866C (en)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US20900700P 2000-06-01 2000-06-01
US60/209,007 2000-06-01
US66403600A 2000-09-18 2000-09-18
US09/664,036 2000-09-18
PCT/US2001/017976 WO2001093110A2 (en) 2000-06-01 2001-06-01 Client side deterministic routing and transparent redirection

Publications (2)

Publication Number Publication Date
CA2410866A1 true CA2410866A1 (en) 2001-12-06
CA2410866C CA2410866C (en) 2012-02-28

Family

ID=26903728

Family Applications (1)

Application Number Title Priority Date Filing Date
CA2410866A Expired - Fee Related CA2410866C (en) 2000-06-01 2001-06-01 Client side deterministic routing and transparent redirection

Country Status (8)

Country Link
EP (1) EP1287662A2 (en)
JP (1) JP2004501443A (en)
KR (1) KR20030022808A (en)
CN (1) CN1446426A (en)
AR (1) AR028659A1 (en)
AU (1) AU2001268160A1 (en)
CA (1) CA2410866C (en)
WO (1) WO2001093110A2 (en)

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SE507138C2 (en) * 1996-10-14 1998-04-06 Mirror Image Internet Ab Procedure and apparatus for information transmission on the Internet

Also Published As

Publication number Publication date
JP2004501443A (en) 2004-01-15
EP1287662A2 (en) 2003-03-05
KR20030022808A (en) 2003-03-17
CA2410866C (en) 2012-02-28
AU2001268160A1 (en) 2001-12-11
WO2001093110A2 (en) 2001-12-06
CN1446426A (en) 2003-10-01
WO2001093110A3 (en) 2002-06-06
AR028659A1 (en) 2003-05-21

Similar Documents

Publication Publication Date Title
US20140185446A1 (en) Synchronizing state among load balancer components
US8407256B2 (en) Arrangement for a distributed file system having data objects mapped independent of any data object attribute
US8423581B2 (en) Proxy support for special subtree entries in a directory information tree using attribute rules
US6654795B1 (en) System and method for distribution of network file accesses over network storage devices
JP5102841B2 (en) Method for distributed directory with proxy, proxy server, and proxy directory system
US8819273B2 (en) Logical routing system
US6760763B2 (en) Server site restructuring
US20080189437A1 (en) Composite DNS zones
US20210336920A1 (en) Method and device for controlling ratio of multi-cname traffic
US6151331A (en) System and method for providing a proxy FARP for legacy storage devices
US20040054793A1 (en) System and method for high performance shared web hosting
WO2006103539B1 (en) System, network entity, method, mobile device and computer program product for correlating device identifiers in mobile networks
SE9603753D0 (en) Internet communication system
AR028660A1 (en) METHOD FOR NETWORK ADDRESSING
CN108667946B (en) Multi-domain name mutual backup analysis management method, device and system
CN101094224A (en) Method and system of providing services, access services, logging in and out services
CA2304628A1 (en) Communications network node
US20150019635A1 (en) Transparent redirection of clients to a surrogate payload server through the use of a proxy location server
US20070106699A1 (en) Method and system for automatic registration of attribute types
CA2213043A1 (en) Non-broadcast multi-access network system capable of carrying out transmission of a next hop resolution protocol packet without setting internet protocol addresses
US6990481B1 (en) System and method for content management over network storage devices
US7418507B2 (en) Virtual resource serving of consolidated server shares
CA2410866A1 (en) Client side deterministic routing and transparent redirection
CN111614792A (en) Transparent transmission method, system, server, electronic device and storage medium
KR970060774A (en) Automatic discovery and automatic network configuration of in-network nodes using SNMP

Legal Events

Date Code Title Description
EEER Examination request
MKLA Lapsed

Effective date: 20180601