CA2316256C - Localization of clients and servers - Google Patents

Localization of clients and servers Download PDF

Info

Publication number
CA2316256C
CA2316256C CA002316256A CA2316256A CA2316256C CA 2316256 C CA2316256 C CA 2316256C CA 002316256 A CA002316256 A CA 002316256A CA 2316256 A CA2316256 A CA 2316256A CA 2316256 C CA2316256 C CA 2316256C
Authority
CA
Canada
Prior art keywords
terminal server
data
geographic location
database
host system
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.)
Expired - Fee Related
Application number
CA002316256A
Other languages
French (fr)
Other versions
CA2316256A1 (en
Inventor
William Kenney
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.)
Microsoft Corp
Original Assignee
Microsoft Technology Licensing LLC
America Online 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 Microsoft Technology Licensing LLC, America Online Inc filed Critical Microsoft Technology Licensing LLC
Publication of CA2316256A1 publication Critical patent/CA2316256A1/en
Application granted granted Critical
Publication of CA2316256C publication Critical patent/CA2316256C/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
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/06Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • G06F11/0709Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a distributed system consisting of a plurality of standalone computer nodes, e.g. clusters, client-server systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • G06F11/073Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a memory management context, e.g. virtual memory or cache management
    • 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/953Querying, e.g. by the use of web search engines
    • G06F16/9537Spatial or temporal dependent retrieval, e.g. spatiotemporal queries
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/19Flow control; Congestion control at layers above the network layer
    • H04L47/193Flow control; Congestion control at layers above the network layer at the transport layer, e.g. TCP related
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/06Message adaptation to terminal or network requirements
    • 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
    • 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/1095Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes
    • 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/52Network services specially adapted for the location of the user terminal

Abstract

A data transfer method includes receiving terminal server identification data at a host system from a terminal server, querying a database to obtain localized information service data associated with the terminal server identification data, and sending the localized information service data from the host system to the terminal server. A host system providing localized information system data includes a database system, a network interface, and a processor. The database system includes records to associate terminal server identification data with information service data. The interface couples the host system to a communications link over which the host system can exchange data with a terminal server. The processor is coupled to the interface and to the database and is configured to receive terminal server identification data from the data interface, to query the database for localized information service data associated with the terminal server identification data, and to send the localized information service data obtained by the query to the data interface for transmission to the terminal server.

Description

= ' - 1 -LOCALIZATION OF CLIENTS AND SERVERS
BACKGROUND
Data service providers can use centralized host computer systems to provide customized information service data to users at remote client computers. The information service data may be localized. That is, the host computer may send data to a user at a remote client computer that is specific to a particular geographic or logical location.
For example, a host computer can provide localized weather service data to users at client computers throughout a country. To localize the weather data, the host system can select different weather data depending on the geographic location of the client computer. Data localization techniques may require that a user identify the location of interest. For example, a user may be prompted to enter address, phone number, zip code or other location identification data needed by a host system to localize data for the particular user.

SUNMARY
Localization of information service data provided by an information service host computer system to users at remote client computer systems can be facilitated by automatically determining a geographic or logical location associated with the client computer system. The automatic determination of a location can be achieved using data identifying the terminal server through which a client computer accesses the host system or computer network.

In accordance with one aspect of the present invention, there is provided a method for data transfer between a host system, a database, and a terminal server, - la -the terminal server having a geographic location, the method comprising: receiving at a host system, a terminal server identifier from a terminal server having a geographic location; querying a database to obtain service data associated with the geographic location of the terminal server based on the terminal server identifier; and autoinatically sending the geographic location specific service data from the host system to the terminal server.

In accordance with a second aspect of the present invention, there is provided a host system comprising: a database including a record associating a terminal server identifier with service data specific to a geographic location; an interface to exchange data with a terminal server situated at a geographic location via a communications link; and a processor configured to receive the terminal server identifier from the data interface, to query the database for geographic location specific service data associated with the terminal server identifier, and to send the geographic location specific service data obtained by the query to the data interface for transmission to the terminal server.

In accordance with a third aspect of the present inver.ition, there is provided a computer program residing on a computer-readable medium, comprising instructions for causing a computer to: receive a terminal server identifier from a terminal server having a geographic location; query a database to obtain geographic location specific service data assoc.iated with the geographic location of the terminal server based on the terminal server identifier; and send the geographic location specific service data to the terminal server.

- lb -In accordance with a fourth aspect of the present invention, there is provided a method for data transfer between a host system, a database, and a terminal server, the terminal server having a geographic location, the method comprising: receiving, at a host system, terminal server identifier from a terminal server having a geographic location; accessing, by the host system, the geographic location of the terminal server based on the terminal server iden-cifier; maintaining, at the host system, geographic location specific service data; querying, at the host system, a database to obtain the geographic location specific service data associated with the geographic location of the terminal server based on the terminal server identifier; and automatically sending the geographic location specific service data from the host system to the term:Lnal server, wherein the host system is a single source for accessing the geographic location of the terminal server, maintaining the geographic location specific service data, and sending the geographic location specific service data to the terminal server.

In general, in another aspect, the invention features a data transfer method. The method includes receiving terminal server identification data at a host syste:m from a terminal server, querying a database to obtain localized information service data associated with the terminal server identification data, and sending the localized information service data from the host system to the terminal server.

In general, in another aspect, the invention features a computer host system. The host system includes a database system, a network interface, and a processor. The data base system SUBSTITUTE
-2-includes records to associate terminal server identification data with information service data.
The interface couples the host system to a communications link over which the host system can exchange data with a terminal server. The processor is coupled to the interface and to the database and is configured to receive terminal server identification data from the data interface, to query the database for localized information service data associated with the terminal server identification data, and to send the localized information service data obtained by the query to the data interface for transmission to the terminal server.
In general, in another aspect, the invention features a computer program residing on a computer-readable medium. The program includes instructions for causing a computer to receive terminal server identification data from a terminal server, to query a database to obtain localized information service data associated with the terminal server identification data, and to send the localized information service data from the host system to the terminal server.
Implementations may include one or more of the following features. A host system database may include records associating terminal server identification data with location data and/or directly associating the identification data with localized information service data.
Data connections may be established between a client computer and the terminal server and between the terminal server and a host computer system. The host system may include packet processing circuitry to receive data packets from the terminal server, and to extract terminal server identification data from a header region of the data packet. For example, the host may extract the terminal server's network address from a data packet and is it as the terminal server identifier. The host may query a database based on the terminal server identification data to determine localized information to be sent to the client computer.
Localization of particular data services may be done in response to a request originating at a client computer identifying a specific information service. In such a case, the host may obtain localized information service data using a database query based on both the terminal server identification data and the specified information service.
The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Implementations may provide advantages such as facilitating access to localized data without requiring user location input. Other features, objects, and advantages of the invention will be apparent from the description and drawings, and from the claims.

AMENDED SHEET
- 3 - PCT/US98/27217 DESCRIPTION OF DRAWINGS
FIG. 1 is a computer hardware diagram.
FIG. 2 is a computer network diagram.
FIG. 3 is a flowchart.

DETAILED DESCRIPTION
Fig. 1 depicts physical resources of a computer system 100. The computer 100 has a central processor 101 connected to a processor host bus 102 over which it provides data, address and control signals. The processors 101 may be any conventional general purpose single- or multi-chip microprocessor such as a Pentium processor, a Pentium Pro processor, a Pentium II processor, a MIPS processor, a Power PC processor or an ALPHA processor. In addition, the processor 101 may be any conventional special purpose microprocessor such as a digital signal processor or a graphics processor. The microprocessor 101 has conventional address, data, and control lines coupling it to a processor host bus 102.
16 The computer 100 includes a system controller 103 having an integrated RAM
memory controller 104. The system controller 103 is connected to the host bus 102 and provides an interface to random access memory 105. The system controller 103 also provides host bus to peripheral bus bridging functions. The controller 103 thereby permits signals on the processor host bus 102 to be compatibly exchanged with signals on a primary peripheral bus 110. The peripheral bus 110 may be, for example, a Peripheral Component Interconnect (PCI) bus, an Industry Standard Architecture (ISA) bus, or a Micro-Channel bus.
Additionally, the controller 103 can provide data buffering and data transfer rate matching between the host bus 102 and peripheral bus 110. The controller 103 thereby allows, for example, a processor 101 having a 64-bit 66 MHz interface and a 533 Mbytes/second data transfer rate to interface to a PCI bus 110 having a data path differing in data path bit width, clock speed, or data transfer rate.
Accessory devices including, for example, a video display controller 112 and network controller 114 can be coupled to the peripheral bus 110. The network controller 114 may be a modem, an Ethernet networking card, a cable modem, or other network access device. The system 100 may also include a secondary peripheral bus 120 coupled to the primary peripheral bus 110 through a bridge controller 111. The secondary peripheral bus 120 can be
- 4 - PCT/US98/27217 included in the system 100 to provide additional peripheral device connection points or to connect peripheral devices that are not compatible with the primary peripheral bus 110. For example, in the system 100, the secondary bus 120 may be an ISA bus and the primary bus 110 may be a PCI bus. Such a configuration allows ISA devices to be coupled to the ISA bus 120 and PCI devices to be coupled to the PCI bus 110. The bridge controller 111 can also include a hard disk drive control interface to couple a hard disk 113 to the peripheral bus 110.
The computer 100 also includes non-volatile ROM memory 122 to store basic computer software routines. ROM 122 may include alterable memory, such as EEPROM
(Electronically Erasable Programmable Read Only Memory), to store configuration data. For 1 o example, EEPROM memory may be used to store hard disk 113 geometry and configuration data. BIOS routines 123 are included in ROM 122 and provide basic computer initialization, systems testing, and input/output (I/O) services. For example, BIOS routines 123 may be executed by the processor 101 to process interrupts that occur when the bridge I 11 attempts to transfer data from the ISA bus 120 to the host bus 102 via the bridge 111, peripheral bus 110, and system controller 103. The BIOS 123 also includes routines that allow an operating system to be "booted" from the disk 113 or from a server computer using a local area network connection provided by the network adapter 114. The operating system boot operation can occur after the computer 100 is turned on and power-on self-test (POST) routines stored in the BIOS 123 complete execution, or when a reset switch is depressed, or following a software-initiated system reset or a software fault. During the boot process, the processor 101 executes BIOS 123 software to access the disk controller 111 or network controller 114 and thereby obtain a high-level operating system. The high-level operating system is, for example, the Microsoft Disk Operating System (DOS)TM, Windows 95TM, Windows NTTM, a UNIX operating system, the Apple MacOS TM operating system, or other operating system.
An operating system may be fully loaded in the RAM memory 105 or may include portions in RAM memory 105, disk drive storage 113, or storage at a network location. For example, the Microsoft Windows 95TM operating system includes some functionality that remains in memory 105 during the use of Windows 95TM and other functionality that is periodically loaded into RAM memory 105 on an as-needed basis from, for example, the disk 113. An operating system, such as Windows 95TM or Windows NT TM provides functionality to control computer peripherals such as devices 112-114, 121, and 124, and to execute user SUBSTITU'I'E
- 5-software, scientific software, internet access software, word processing software, and many other types of software. User applications may access computer system peripherals 112-114, 121, and 124 through an application programming interface provided by the operating system and/or may directly interact with underlying computer system 100 hardware.
A collection of computers 100 can serve as components of a computer network.
As shown in Fig. 2, a computer network 200 can include a host computer system 210 and client computers 231-236. The client computers 231-236 can communicate with the host 210 to obtain data stored at the host 210 in databases 214-215. The client computer 231-236 may interact with the host computer 210 as if the host was a single entity in the network 200.
However, the host 210 may include multiple processing and database sub-systems that can be geographically dispersed throughout the network 200. For example, a host 210 may include a tightly coupled cluster 211-213 of computers 100 (Fig. 1) at a first location that access database systems 2 14-2 15 at remote locations. Each database system 2 14-2 15 may include additional processing components.
Client computers 231-236 can communicate with the host system 210 over, for example, a combination of public switched telephone network dial-up connections and packet network interconnections. For example, client computers 23 1-233 may each include a modem coupled to voiceband telephone line 241-243. To communicate with the host 210, the client computers 231-233 establish a data connection with a local terminal server 225 by dialing a telephone number assigned to the local terminal server 225. A local terminal server 225 may have both dial-up and packet network interfaces allowing the server 225 to receive data from client computers 23 1-233, segment the received data into data packet payload segments, add overhead information to the payload segments, and send the resultant data packets over a link 221 to a packet data network 220 for delivery to the host system 210. Terminal servers 225 and 226 may also be referred to as a network service provider's point-of-presence (POP).
The overhead information added to the payload segments includes a packet header. A
packet header includes a destination address assigned to the host system 210 and a source address assigned to the local terminal server 225. Other overhead information may include _ information associating the data packet with a specific client 231-233.
Similarly, the host system 210 may send data to a client 231-233 by segmenting the data internet packet payload segments, and adding overhead information to send the data packet to a client 231-234 at the terminal server 225. Client computers 234-236 may similarly exchange data with the host 210 over communications links 244-246 to the terminal server 226.

AiVENDED SHEET
- 6 - PCT/US98/27217 payload segments, and adding overhead information to send the data packet to a client 231-234 at the terminal server 225. Client computers 234-236 may similarly exchange data with the host 210 over communications links 244-246 to the terminal server 226.
Data packet formats, switching equipment within the packet network 220, and networking protocols used within the network 200 may conform to the transaction control protocol / internet protocol (TCP/IP). In a TCP/IP implementation, the host 210, packet network 220, terminal servers 225 and 226 are each assigned a unique internet protocol (IP) network address. TCP/IP switching equipment within the network 220 can direct a TCP/IP
packet to the intended recipient 210, 225, or 226 based on the packet's destination IP address.
1o Implementations may use other networking protocols and packet formats.
The host computer 210 can provide information services to one or more client computers 231-236. Information services provided by the host 210 include, for example, weather reports, sports team scores, travel, shopping services, games, personal finance, local, national, and international news, local traffic conditions and other general and special interest data services. The America Online Version 4.0 service, available from America Online, Inc., is an example of an information service using a host system 210 to deliver a broad range of information services to multiple client computers. In an America Online implementation, a client computers 231-236 can be a personal computer such as an Apple MacintoshTM or industry-standard Intel x86 compatible computer. In the America Online Version 4.0 system, client computers execute America Online Version 4.0 client software to access a host system using, for example, a voiceband modem, a cable modem, or a TCP/IP connection.
Information service data provided by a host 210 can include localized data.
Localized information service data can be automatically determined based on the location of the terminal server 225-226 or other point-of-presence through which the client accesses the network 200. Automatic localization based on the location of a terminal server or POP allows information service data to be localized without requiring manual location input by a user.
Referring to Figs. 2 and 3, in an automated localization system, a client 231 connects to a terminal server 225 or other network point-of-presence. The terminal server 225 may then send information between the client 231 and host 210 through the packet network 220.
3o Overhead information in the data packets sent from the terminal server 225 to the host 210 include terminal server identification information, such as the terminal server's network address (step 303). When a data packet is received at the host system 210, the host uses the
- 7 - PCT/US98/27217 received terminal server identification information to determine the location of the terminal server 225 (step 304). The host system 210 may then obtain localized data from a database 214 or 215 by querying the database based on the terminal server's location (step 304). The localized data is subsequently sent from the host system to the client computer (step 305).
A host system may include information service databases that directly associates terminal server ID information with localized information service data and can be queried based on the terminal server ID information. In such a case, the determination of a location is implicit in the query for the localized information. AlternativeIy, a host system may first determine a location based on the tenminal server ID and then query an information service database based on the determined location. Other query systems may also be used to map terminal server identification data to localized data.
In an internet protocol (IP) implementation, the terminal server ID
information may be an internet protocol (IP) address assigned to the terminal server. The terminal server's IP
address may be used to query a host database table that maps IP address information to location information. Table 1 shows an exemplary database table to map IP
addresses to locations.

Table 1 - Exemplary IP to Location Mapping Data IP Address Location Location Name 127. 0. 0. 255 AA12 ABC Corporation 255. 255. 255. 0 BB34 Anytown USA
64. 112. 15. 86 AA12 ABC Corporation 89. 3. 255. * CD89 Country Name 77. 4. * * CA86 State of ABC

Using the data in Table 1, a host 210 receiving a data packet from a tenminal server having the IP address 127Ø0.255 can map the IP address to a location identifier "AA12."
The host may then query an information service database 214 to obtain localized information service data corresponding to the location "AA12." The localized information service data can then be sent back to a client for display to a user. "Wild-card" entries (shown as "*" in Table 1) can allow a broad range of addresses to be mapped to a location identifier. For example, the IP address entry "77.4.*.*" in the fifth row of Table l will match any received IP address beginning with "77.4" to the location identifier "CA86."

WO 99/34305 - g - PCT/US98/27217 Implementations may use data other than a network addresses to identify a terminal server. For example, in a simple network management protocol (SNMP) implementation, a SNMP-capable terminal server can access identification data stored in one or more of the terminal server's management information bases (MIBs) and include that identification data in data packets sent to the host 310. For example, a terminal server may access a MIB
containing vendor, model, and serial number information for the terminal server and can send the vendor, model, and serial number information to the hosts to be used as a terminal server identifier for localization purposes.
A host system may map a terminal server ID to a physical location or to a logical location. In a physical location mapping implementation, the terminal server ID identifies a geographic location. For example, the terminal server ID may be mapped to a region of a country and weather information service data for that region could be provided to a client. In a logical location mapping implementation, the terminal server ID identifies a logical location such as a corporation. Thus, for example, in a logical mapping implementation, a terminal server may be dedicated to clients from a particular corporation. All clients within that corporation could then receive localized news information service data discussing that corporation.
The invention may be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. Apparatus of the invention may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor; and method steps of the invention may be performed by a programmable processor executing a program of instructions to perform functions of the invention by operating on input data and generating output. The invention may advantageously be implemented in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device.
Each computer program may be implemented in a high-level procedural or object-oriented programming language, or in assembly or machine language if desired; and in any case, the language may 3o be a compiled or interpreted language. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory. Storage devices suitable SUBSTITUTE

integrated circuits).
A number of embodiments of the present invention have been described.
Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. For example, the terminal server is not limited to a modem bank. A tenninal server may be a proxy server, network gateway, network firewall, or other network element through which client computers connect to a host system and which allow a location to be associated with a client.

5~1~~;
woon

Claims (24)

CLAIMS:
1. A method for data transfer between a host system, a database, and a terminal server, the terminal server having a geographic location, the method comprising:

receiving at a host system, a terminal server identifier from a terminal server having a geographic location;

querying a database to obtain service data associated with the geographic location of the terminal server based on the terminal server identifier; and automatically sending the geographic location specific service data from the host system to the terminal server.
2. The method of claim 1 wherein the database includes a first record that associates the terminal server identifier with the geographic location, and querying the database includes determining the geographic location based on the terminal server identifier data from the first record.
3. The method of claim 2 wherein the database further includes a record that associates the geographic location with service data that is specific to the geographic location, and querying the database further comprises determining the geographic location specific service data based on the determined geographic location.
4. The method of claim 1 further comprising:
establishing a data connection between the terminal server and a client computer;

receiving the geographic location specific service data at the terminal server; and forwarding the geographic location specific service data from the terminal server to the client computer.
5. The method of claim 4 wherein establishing a data connection is carried out prior to receiving the terminal server identifier.
6. The method of claim 4 wherein establishing a data connection further comprises receiving a dial-up modem connection from a client computer.
7. The method of claim 1 wherein the terminal server identifier comprises a network address associated with the terminal server.
8. The method of claim 7 wherein receiving the terminal server identifier further comprises receiving a data packet from the terminal server, the data packet including the terminal server network address.
9. The method of claim 8 wherein the data packet includes request data received at the terminal server from the client computer, the request data identifying an information service.
10. The method of claim 9 wherein querying the database further comprises querying based on the terminal server identifier and the request data; and the geographic location specific service data obtained by the query of the database is associated with both the terminal server identifier data and with the service identified by the request data.
11. A host system comprising:

a database including a record associating a terminal server identifier with service data specific to a geographic location;

an interface to exchange data with a terminal server situated at a geographic location via a communications link; and a processor configured to receive the terminal server identifier from the data interface, to query the database for geographic location specific service data associated with the terminal server identifier, and to send the geographic location specific service data obtained by the query to the data interface for transmission to the terminal server.
12. The host system of claim 11 wherein:

the terminal server identifier comprises a network address associated with the terminal server; and the interface includes packet processing circuitry to receive a data packet from the terminal server and extract the terminal server identifier from a header region of the data packet.
13. The host system of claim 12 wherein the network address comprises an internet protocol address.
14. The host system of claim 11 wherein the database includes a disk storage medium comprising a plurality of records associating terminal server identifiers with geographic locations and a plurality of records associating geographic locations with service data.
15. The host system of claim 14 further comprising a software storage media coupled to the processor, the media storing instructions to configure the processor to query the database, instructions to retrieve geographic locations associated with terminal server identifiers and instructions to query the database to retrieve service data associated with geographic locations.
16. A computer program residing on a computer-readable medium, comprising instructions for causing a computer to:
receive a terminal server identifier from a terminal server having a geographic location;

query a database to obtain geographic location specific service data associated with the geographic location of the terminal server based on the terminal server identifier; and send the geographic location specific service data to the terminal server.
17. The computer program of claim 16 wherein the instructions to query the database comprise instructions to query the database to determine the geographic location based on the received terminal server identifier.
18. The computer program of claim 16 wherein the terminal server identifier comprises a network address associated with the terminal server.
19. The computer program of claim 16 wherein the instructions to receive the terminal server identifier comprises instructions to receive a data packet from the terminal server, the data packet including a terminal server network address.
20. The computer program of claim 19 wherein the data packet further comprises request data received at the terminal server from a client computer, the request data identifying a service.
21. The computer program of claim 20 wherein:

the instructions to query the database comprise instructions to query the database based on the terminal server identifier and the request data; and the geographic location specific service data obtained by the query is associated with both the terminal server identifier and with the service identified by the request data.
22. A method for data transfer between a host system, a database, and a terminal server, the terminal server having a geographic location, the method comprising:

receiving, at a host system, terminal server identifier from a terminal server having a geographic location;

accessing, by the host system, the geographic location of the terminal server based on the terminal server identifier;

maintaining, at the host system, geographic location specific service data;

querying, at the host system, a database to obtain the geographic location specific service data associated with the geographic location of the terminal server based on the terminal server identifier; and automatically sending the geographic location specific service data from the host system to the terminal server, wherein the host system is a single source for accessing the geographic location of the terminal server, maintaining the geographic location specific service data, and sending the geographic location specific service data to the terminal server.
23. The method as in claim 22 further comprising:
establishing a data connection between the terminal server and a client computer;

receiving the geographic location specific data at the terminal server; and forwarding the geographic location specific service data from the terminal server to the client computer.
24. The method as in claim 22 wherein the terminal server identifier includes a network address associated with the terminal server.
CA002316256A 1997-12-24 1998-12-22 Localization of clients and servers Expired - Fee Related CA2316256C (en)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US6886897P 1997-12-24 1997-12-24
US60/068,868 1997-12-24
US7061798P 1998-01-06 1998-01-06
US60/070,617 1998-01-06
PCT/US1998/027217 WO1999034305A1 (en) 1997-12-24 1998-12-22 Localization of clients and servers

Publications (2)

Publication Number Publication Date
CA2316256A1 CA2316256A1 (en) 1999-07-08
CA2316256C true CA2316256C (en) 2009-02-24

Family

ID=26749467

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002316256A Expired - Fee Related CA2316256C (en) 1997-12-24 1998-12-22 Localization of clients and servers

Country Status (7)

Country Link
US (5) US9009345B1 (en)
EP (1) EP1040431B1 (en)
AT (1) ATE292306T1 (en)
AU (3) AU1940199A (en)
CA (1) CA2316256C (en)
DE (1) DE69829584T2 (en)
WO (3) WO1999034555A2 (en)

Families Citing this family (174)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2316256C (en) * 1997-12-24 2009-02-24 America Online, Inc. Localization of clients and servers
US6647532B1 (en) * 1998-10-29 2003-11-11 Dell Usa L.P. Built-in automatic customer identifier when connecting to a vendor website
US6757740B1 (en) 1999-05-03 2004-06-29 Digital Envoy, Inc. Systems and methods for determining collecting and using geographic locations of internet users
CA2379159C (en) * 1999-07-12 2013-07-02 Telefonaktiebolaget Lm Ericsson Method and system for exchanging information between multimedia network nodes
TW516309B (en) * 1999-12-10 2003-01-01 United Video Properties Inc Features for use with advanced set-top applications on interactive television systems
JP3319731B2 (en) * 1999-12-27 2002-09-03 敬介 山本 Information transmission method
DE10014090A1 (en) * 2000-03-22 2001-11-29 Siemens Ag Providing geographical information from communication system when requested using www or WAP service - using intermediate station to add geographical location information to request for information
EP1277125A4 (en) * 2000-04-03 2005-03-02 Quova Inc Method and apparatus for estimating a geographic location of a networked entity
US6684250B2 (en) 2000-04-03 2004-01-27 Quova, Inc. Method and apparatus for estimating a geographic location of a networked entity
US20030018769A1 (en) * 2000-07-26 2003-01-23 Davis Foulger Method of backtracing network performance
WO2002013459A2 (en) * 2000-08-04 2002-02-14 Digital Envoy, Inc. Determining geographic locations of private network internet users
WO2002017139A1 (en) * 2000-08-18 2002-02-28 Akamai Technologies, Inc. Method and system for providing content providers with information about how their users access the internet
US7210094B2 (en) * 2001-07-11 2007-04-24 International Business Machines Corporation Method and system for dynamic web page breadcrumbing using javascript
FR2838267B1 (en) * 2002-04-09 2004-05-14 France Telecom TELECOMMUNICATION SYSTEM VIA A MAIN INTERNET-TYPE NETWORK AND A CABLE TERMINAL FOR GEOGRAPHICALLY RELEVANT ROUTING OF COMMUNICATIONS
US8510682B2 (en) 2002-12-20 2013-08-13 Sap Ag Unifying navigation model
US7499914B2 (en) * 2003-04-04 2009-03-03 Yahoo! Inc. Search system using search subdomain and hints to subdomains in search query statements and sponsored results on a subdomain-by-subdomain basis
US8015501B2 (en) * 2003-08-18 2011-09-06 Sap Aktiengesellschaft Accessing previously viewed windows
US7962843B2 (en) * 2003-12-15 2011-06-14 Microsoft Corporation Browser session overview
US7774721B2 (en) * 2003-12-15 2010-08-10 Microsoft Corporation Intelligent backward resource navigation
CN1910540B (en) * 2004-01-09 2012-04-25 皇家飞利浦电子股份有限公司 Two panel navigation
US8639819B2 (en) * 2004-02-05 2014-01-28 Nokia Corporation Ad-hoc connection between electronic devices
US7802262B1 (en) 2004-03-05 2010-09-21 Adobe Systems Incorporated System and method for communicating state and title information between a browser and a rich internet application with browser forward and back button support
US7934210B1 (en) 2004-03-26 2011-04-26 Adobe Systems Incorporated System and method for updating one or more programs and their environment
US7808925B2 (en) 2004-09-10 2010-10-05 Digital Envoy, Inc. Methods and systems for determining reverse DNS entries
US7497374B2 (en) 2004-09-17 2009-03-03 Digital Envoy, Inc. Fraud risk advisor
US7543740B2 (en) 2004-09-17 2009-06-09 Digital Envoy, Inc. Fraud analyst smart cookie
US8032594B2 (en) 2004-11-10 2011-10-04 Digital Envoy, Inc. Email anti-phishing inspector
US7774753B1 (en) 2004-11-18 2010-08-10 Adobe Systems Incorporated System and method for communicating data among two or more programs
US20060224951A1 (en) * 2005-03-30 2006-10-05 Yahoo! Inc. Multiple window browser interface and system and method of generating multiple window browser interface
JP2008547136A (en) * 2005-06-28 2008-12-25 クラリア コーポレイション Method and system for controlling and adapting media streams
US8001458B1 (en) * 2005-11-14 2011-08-16 Adobe Systems Incorporated System and method for communicating state and title information between a browser and a rich Internet application
US9367832B2 (en) 2006-01-04 2016-06-14 Yahoo! Inc. Synchronizing image data among applications and devices
FR2906382B1 (en) * 2006-09-25 2008-11-14 Canon Kk METHODS AND DEVICES FOR OPTIMIZING XML PROCESSING
US20080295018A1 (en) * 2007-05-24 2008-11-27 Nokia Corporation Apparatus, method and computer program product providing an adaptive forward button for a browser application
US8230417B1 (en) 2007-06-08 2012-07-24 Adobe Systems Incorporated Combined application and execution environment install
US8028090B2 (en) 2008-11-17 2011-09-27 Amazon Technologies, Inc. Request routing utilizing client location information
US7991910B2 (en) * 2008-11-17 2011-08-02 Amazon Technologies, Inc. Updating routing information based on client location
US8375381B1 (en) 2007-07-30 2013-02-12 Adobe Systems Incorporated Management user interface for application execution environment
US7930273B1 (en) 2007-07-30 2011-04-19 Adobe Systems Incorporated Version management for application execution environment
US8448161B2 (en) 2007-07-30 2013-05-21 Adobe Systems Incorporated Application tracking for application execution environment
US9858053B2 (en) * 2008-02-08 2018-01-02 Reservoir Labs, Inc. Methods and apparatus for data transfer optimization
US8533293B1 (en) 2008-03-31 2013-09-10 Amazon Technologies, Inc. Client side cache management
US7962597B2 (en) 2008-03-31 2011-06-14 Amazon Technologies, Inc. Request routing based on class
US8156243B2 (en) 2008-03-31 2012-04-10 Amazon Technologies, Inc. Request routing
US8606996B2 (en) 2008-03-31 2013-12-10 Amazon Technologies, Inc. Cache optimization
US8321568B2 (en) 2008-03-31 2012-11-27 Amazon Technologies, Inc. Content management
US8447831B1 (en) 2008-03-31 2013-05-21 Amazon Technologies, Inc. Incentive driven content delivery
US7970820B1 (en) 2008-03-31 2011-06-28 Amazon Technologies, Inc. Locality based content distribution
US8601090B1 (en) 2008-03-31 2013-12-03 Amazon Technologies, Inc. Network resource identification
US8275720B2 (en) 2008-06-12 2012-09-25 International Business Machines Corporation External scoping sources to determine affected people, systems, and classes of information in legal matters
US9830563B2 (en) 2008-06-27 2017-11-28 International Business Machines Corporation System and method for managing legal obligations for data
US9407681B1 (en) 2010-09-28 2016-08-02 Amazon Technologies, Inc. Latency measurement in resource requests
US8327384B2 (en) * 2008-06-30 2012-12-04 International Business Machines Corporation Event driven disposition
US8484069B2 (en) 2008-06-30 2013-07-09 International Business Machines Corporation Forecasting discovery costs based on complex and incomplete facts
US8489439B2 (en) 2008-06-30 2013-07-16 International Business Machines Corporation Forecasting discovery costs based on complex and incomplete facts
US8515924B2 (en) 2008-06-30 2013-08-20 International Business Machines Corporation Method and apparatus for handling edge-cases of event-driven disposition
US9912740B2 (en) 2008-06-30 2018-03-06 Amazon Technologies, Inc. Latency measurement in resource requests
US7925782B2 (en) 2008-06-30 2011-04-12 Amazon Technologies, Inc. Request routing using network computing components
US8117306B1 (en) 2008-09-29 2012-02-14 Amazon Technologies, Inc. Optimizing content management
US8122124B1 (en) 2008-09-29 2012-02-21 Amazon Technologies, Inc. Monitoring performance and operation of data exchanges
US7930393B1 (en) 2008-09-29 2011-04-19 Amazon Technologies, Inc. Monitoring domain allocation performance
US7865594B1 (en) 2008-09-29 2011-01-04 Amazon Technologies, Inc. Managing resources consolidation configurations
US8316124B1 (en) 2008-09-29 2012-11-20 Amazon Technologies, Inc. Managing network data display
US8286176B1 (en) 2008-09-29 2012-10-09 Amazon Technologies, Inc. Optimizing resource configurations
US8073940B1 (en) 2008-11-17 2011-12-06 Amazon Technologies, Inc. Managing content delivery network service providers
US8060616B1 (en) 2008-11-17 2011-11-15 Amazon Technologies, Inc. Managing CDN registration by a storage provider
US8122098B1 (en) 2008-11-17 2012-02-21 Amazon Technologies, Inc. Managing content delivery network service providers by a content broker
US8732309B1 (en) 2008-11-17 2014-05-20 Amazon Technologies, Inc. Request routing utilizing cost information
US8521880B1 (en) 2008-11-17 2013-08-27 Amazon Technologies, Inc. Managing content delivery network service providers
US8065417B1 (en) 2008-11-17 2011-11-22 Amazon Technologies, Inc. Service provider registration by a content broker
US8839096B2 (en) * 2009-01-14 2014-09-16 International Business Machines Corporation Management of rotating browser content
US7917618B1 (en) 2009-03-24 2011-03-29 Amazon Technologies, Inc. Monitoring web site content
US8412823B1 (en) 2009-03-27 2013-04-02 Amazon Technologies, Inc. Managing tracking information entries in resource cache components
US8521851B1 (en) 2009-03-27 2013-08-27 Amazon Technologies, Inc. DNS query processing using resource identifiers specifying an application broker
US8756341B1 (en) 2009-03-27 2014-06-17 Amazon Technologies, Inc. Request routing utilizing popularity information
US8688837B1 (en) 2009-03-27 2014-04-01 Amazon Technologies, Inc. Dynamically translating resource identifiers for request routing using popularity information
US8782236B1 (en) 2009-06-16 2014-07-15 Amazon Technologies, Inc. Managing resources using resource expiration data
US20100333151A1 (en) * 2009-06-30 2010-12-30 Gemstar Development Corporation Cross platform entertainment architecture
US8397073B1 (en) 2009-09-04 2013-03-12 Amazon Technologies, Inc. Managing secure content in a content delivery network
US8433996B2 (en) 2009-09-15 2013-04-30 Oracle International Corporation Hierarchical model for web browser navigation
US8433771B1 (en) 2009-10-02 2013-04-30 Amazon Technologies, Inc. Distribution network with forward resource propagation
US8443107B2 (en) 2009-11-11 2013-05-14 Digital Envoy, Inc. Method, computer program product and electronic device for hyper-local geo-targeting
US8331370B2 (en) 2009-12-17 2012-12-11 Amazon Technologies, Inc. Distributed routing architecture
US8331371B2 (en) 2009-12-17 2012-12-11 Amazon Technologies, Inc. Distributed routing architecture
US8655856B2 (en) 2009-12-22 2014-02-18 International Business Machines Corporation Method and apparatus for policy distribution
US8250041B2 (en) 2009-12-22 2012-08-21 International Business Machines Corporation Method and apparatus for propagation of file plans from enterprise retention management applications to records management systems
US9495338B1 (en) 2010-01-28 2016-11-15 Amazon Technologies, Inc. Content distribution network
US8812522B2 (en) * 2010-02-12 2014-08-19 Telefonaktiebolaget L M Ericsson (Publ) Managing a navigation history
JP2011170689A (en) * 2010-02-19 2011-09-01 Sony Corp Apparatus and method for processing information, and program
US10095530B1 (en) 2010-05-28 2018-10-09 Bromium, Inc. Transferring control of potentially malicious bit sets to secure micro-virtual machine
US9104837B1 (en) 2012-06-18 2015-08-11 Bromium, Inc. Exposing subset of host file systems to restricted virtual machines based on upon performing user-initiated actions against host files
US9116733B2 (en) 2010-05-28 2015-08-25 Bromium, Inc. Automated provisioning of secure virtual execution environment using virtual machine templates based on requested activity
US8862737B2 (en) * 2010-06-24 2014-10-14 Microsoft Corporation Application integration of network data based on resource identifiers
US8832148B2 (en) 2010-06-29 2014-09-09 International Business Machines Corporation Enterprise evidence repository
US8566903B2 (en) 2010-06-29 2013-10-22 International Business Machines Corporation Enterprise evidence repository providing access control to collected artifacts
US8484569B2 (en) 2010-06-30 2013-07-09 International Business Machines Corporation Saving and restoring collaborative applications in context
US8402359B1 (en) * 2010-06-30 2013-03-19 International Business Machines Corporation Method and apparatus for managing recent activity navigation in web applications
US8577992B1 (en) 2010-09-28 2013-11-05 Amazon Technologies, Inc. Request routing management based on network components
US10958501B1 (en) 2010-09-28 2021-03-23 Amazon Technologies, Inc. Request routing information based on client IP groupings
US8819283B2 (en) 2010-09-28 2014-08-26 Amazon Technologies, Inc. Request routing in a networked environment
US8938526B1 (en) 2010-09-28 2015-01-20 Amazon Technologies, Inc. Request routing management based on network components
US8930513B1 (en) 2010-09-28 2015-01-06 Amazon Technologies, Inc. Latency measurement in resource requests
US8468247B1 (en) 2010-09-28 2013-06-18 Amazon Technologies, Inc. Point of presence management in request routing
US8924528B1 (en) 2010-09-28 2014-12-30 Amazon Technologies, Inc. Latency measurement in resource requests
US9712484B1 (en) 2010-09-28 2017-07-18 Amazon Technologies, Inc. Managing request routing information utilizing client identifiers
US9003035B1 (en) 2010-09-28 2015-04-07 Amazon Technologies, Inc. Point of presence management in request routing
US10097398B1 (en) 2010-09-28 2018-10-09 Amazon Technologies, Inc. Point of presence management in request routing
US8452874B2 (en) 2010-11-22 2013-05-28 Amazon Technologies, Inc. Request routing processing
US8626950B1 (en) 2010-12-03 2014-01-07 Amazon Technologies, Inc. Request routing processing
US9391949B1 (en) 2010-12-03 2016-07-12 Amazon Technologies, Inc. Request routing processing
US9430118B2 (en) * 2011-04-19 2016-08-30 International Business Machines Corporation Spatially-oriented traversal animations for network address transitions
US10467042B1 (en) 2011-04-27 2019-11-05 Amazon Technologies, Inc. Optimized deployment based upon customer locality
US8839245B1 (en) 2012-06-18 2014-09-16 Bromium, Inc. Transferring files using a virtualized application
US8799404B2 (en) * 2011-05-26 2014-08-05 Adobe Systems Incorporated Weather analytics systems and methods
US8396920B1 (en) * 2011-11-30 2013-03-12 Google Inc. Clean URLs in web applications
US8904009B1 (en) 2012-02-10 2014-12-02 Amazon Technologies, Inc. Dynamic content delivery
US10021179B1 (en) 2012-02-21 2018-07-10 Amazon Technologies, Inc. Local resource delivery network
EP2637098B1 (en) * 2012-03-08 2018-09-19 BlackBerry Limited Object mediated data transfer between electronic devices
US9083743B1 (en) 2012-03-21 2015-07-14 Amazon Technologies, Inc. Managing request routing information utilizing performance information
US10623408B1 (en) 2012-04-02 2020-04-14 Amazon Technologies, Inc. Context sensitive object management
US9154551B1 (en) 2012-06-11 2015-10-06 Amazon Technologies, Inc. Processing DNS queries to identify pre-processing information
CN102685257B (en) * 2012-06-11 2016-01-27 深圳中兴网信科技有限公司 Data synchronization processing system, data synchronizing processing method, server system
US10095662B1 (en) 2012-06-18 2018-10-09 Bromium, Inc. Synchronizing resources of a virtualized browser
US9201850B1 (en) 2012-06-18 2015-12-01 Bromium, Inc. Composing the display of a virtualized web browser
US11023088B2 (en) 2012-06-18 2021-06-01 Hewlett-Packard Development Company, L.P. Composing the display of a virtualized web browser
US9727534B1 (en) 2012-06-18 2017-08-08 Bromium, Inc. Synchronizing cookie data using a virtualized browser
US9734131B1 (en) * 2012-06-18 2017-08-15 Bromium, Inc. Synchronizing history data across a virtualized web browser
US9525659B1 (en) 2012-09-04 2016-12-20 Amazon Technologies, Inc. Request routing utilizing point of presence load information
US9953093B1 (en) * 2012-09-04 2018-04-24 Google Llc Mapping system for a browser history stack and a browser page state
US9323577B2 (en) 2012-09-20 2016-04-26 Amazon Technologies, Inc. Automated profiling of resource usage
US9135048B2 (en) 2012-09-20 2015-09-15 Amazon Technologies, Inc. Automated profiling of resource usage
US10205698B1 (en) 2012-12-19 2019-02-12 Amazon Technologies, Inc. Source-dependent address resolution
US9342530B2 (en) * 2013-02-22 2016-05-17 Pro Softnet Corporation Method for skipping empty folders when navigating a file system
US20140258875A1 (en) * 2013-03-11 2014-09-11 Appsense Limited Systems, methods and media for providing historical navigation controls for a mobile device user
US9294391B1 (en) 2013-06-04 2016-03-22 Amazon Technologies, Inc. Managing network computing components utilizing request routing
US10430614B2 (en) 2014-01-31 2019-10-01 Bromium, Inc. Automatic initiation of execution analysis
CN105573574A (en) * 2014-10-09 2016-05-11 阿里巴巴集团控股有限公司 Application interface navigation method and apparatus
US10091096B1 (en) 2014-12-18 2018-10-02 Amazon Technologies, Inc. Routing mode and point-of-presence selection service
US10097448B1 (en) 2014-12-18 2018-10-09 Amazon Technologies, Inc. Routing mode and point-of-presence selection service
US10033627B1 (en) 2014-12-18 2018-07-24 Amazon Technologies, Inc. Routing mode and point-of-presence selection service
US10225326B1 (en) 2015-03-23 2019-03-05 Amazon Technologies, Inc. Point of presence based data uploading
US9819567B1 (en) 2015-03-30 2017-11-14 Amazon Technologies, Inc. Traffic surge management for points of presence
US9887932B1 (en) 2015-03-30 2018-02-06 Amazon Technologies, Inc. Traffic surge management for points of presence
US9887931B1 (en) 2015-03-30 2018-02-06 Amazon Technologies, Inc. Traffic surge management for points of presence
US9832141B1 (en) 2015-05-13 2017-11-28 Amazon Technologies, Inc. Routing based request correlation
US10616179B1 (en) 2015-06-25 2020-04-07 Amazon Technologies, Inc. Selective routing of domain name system (DNS) requests
US10097566B1 (en) 2015-07-31 2018-10-09 Amazon Technologies, Inc. Identifying targets of network attacks
CN105159524A (en) * 2015-08-03 2015-12-16 小米科技有限责任公司 Interface display method and apparatus
US9794281B1 (en) 2015-09-24 2017-10-17 Amazon Technologies, Inc. Identifying sources of network attacks
US9774619B1 (en) 2015-09-24 2017-09-26 Amazon Technologies, Inc. Mitigating network attacks
US9742795B1 (en) 2015-09-24 2017-08-22 Amazon Technologies, Inc. Mitigating network attacks
US10601894B1 (en) 2015-09-28 2020-03-24 Amazon Technologies, Inc. Vector-based encoding for content rendering
US10691750B1 (en) * 2015-09-28 2020-06-23 Amazon Technologies, Inc. Browser configured to efficiently store browsing session state
US10270878B1 (en) 2015-11-10 2019-04-23 Amazon Technologies, Inc. Routing for origin-facing points of presence
US10257307B1 (en) 2015-12-11 2019-04-09 Amazon Technologies, Inc. Reserved cache space in content delivery networks
US10049051B1 (en) 2015-12-11 2018-08-14 Amazon Technologies, Inc. Reserved cache space in content delivery networks
US10348639B2 (en) 2015-12-18 2019-07-09 Amazon Technologies, Inc. Use of virtual endpoints to improve data transmission rates
US10075551B1 (en) 2016-06-06 2018-09-11 Amazon Technologies, Inc. Request management for hierarchical cache
US10110694B1 (en) 2016-06-29 2018-10-23 Amazon Technologies, Inc. Adaptive transfer rate for retrieving content from a server
US9992086B1 (en) 2016-08-23 2018-06-05 Amazon Technologies, Inc. External health checking of virtual private cloud network environments
US10033691B1 (en) 2016-08-24 2018-07-24 Amazon Technologies, Inc. Adaptive resolution of domain name requests in virtual private cloud network environments
US10469513B2 (en) 2016-10-05 2019-11-05 Amazon Technologies, Inc. Encrypted network addresses
US10372499B1 (en) 2016-12-27 2019-08-06 Amazon Technologies, Inc. Efficient region selection system for executing request-driven code
US10831549B1 (en) 2016-12-27 2020-11-10 Amazon Technologies, Inc. Multi-region request-driven code execution system
US10938884B1 (en) 2017-01-30 2021-03-02 Amazon Technologies, Inc. Origin server cloaking using virtual private cloud network environments
US10503613B1 (en) 2017-04-21 2019-12-10 Amazon Technologies, Inc. Efficient serving of resources during server unavailability
US10965572B2 (en) 2017-05-01 2021-03-30 Bank Of America Corporation Data transfer control
US11075987B1 (en) 2017-06-12 2021-07-27 Amazon Technologies, Inc. Load estimating content delivery network
US10447648B2 (en) 2017-06-19 2019-10-15 Amazon Technologies, Inc. Assignment of a POP to a DNS resolver based on volume of communications over a link between client devices and the POP
CN107357644B (en) * 2017-06-30 2018-10-16 腾讯科技(深圳)有限公司 Applied program processing method, device, storage medium and computer equipment
US10742593B1 (en) 2017-09-25 2020-08-11 Amazon Technologies, Inc. Hybrid content request routing system
US10592578B1 (en) 2018-03-07 2020-03-17 Amazon Technologies, Inc. Predictive content push-enabled content delivery network
US10862852B1 (en) 2018-11-16 2020-12-08 Amazon Technologies, Inc. Resolution of domain name requests in heterogeneous network environments
US11025747B1 (en) 2018-12-12 2021-06-01 Amazon Technologies, Inc. Content request pattern-based routing system

Family Cites Families (50)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5481710A (en) 1992-09-16 1996-01-02 International Business Machines Corporation Method of and system for providing application programs with an undo/redo function
CA2128306C (en) 1993-09-14 1998-12-15 Marjorie Susan Backaus Personalized information service system
NL9301633A (en) 1993-09-21 1995-04-18 Nederland Ptt Method for identifying users of telematics servers.
US5426643A (en) * 1993-11-01 1995-06-20 Motorola Inc. Apparatus and method for transmitting bit synchronous data over an unreliable channel
US6769009B1 (en) 1994-05-31 2004-07-27 Richard R. Reisman Method and system for selecting a personalized set of information channels
JPH0816446A (en) * 1994-07-05 1996-01-19 Fujitsu Ltd Client server system
US5598410A (en) * 1994-12-29 1997-01-28 Storage Technology Corporation Method and apparatus for accelerated packet processing
US5654886A (en) * 1995-03-14 1997-08-05 Wsi Corporation Multimedia outdoor information system
US5740549A (en) * 1995-06-12 1998-04-14 Pointcast, Inc. Information and advertising distribution system and method
FI105754B (en) 1995-06-12 2000-09-29 Nokia Oy Ab Transfer protocol for transferring files on the DAB system
US5941947A (en) * 1995-08-18 1999-08-24 Microsoft Corporation System and method for controlling access to data entities in a computer network
US5717860A (en) 1995-09-20 1998-02-10 Infonautics Corporation Method and apparatus for tracking the navigation path of a user on the world wide web
US5799016A (en) * 1996-01-11 1998-08-25 U S West, Inc. Network addressing scheme encoding communication channel information
US5764911A (en) * 1996-02-13 1998-06-09 Hitachi, Ltd. Management system for updating network managed by physical manager to match changed relation between logical objects in conformity with changed content notified by logical manager
US5913214A (en) * 1996-05-30 1999-06-15 Massachusetts Inst Technology Data extraction from world wide web pages
US5857203A (en) * 1996-07-29 1999-01-05 International Business Machines Corporation Method and apparatus for dividing, mapping and storing large digital objects in a client/server library system
US6195691B1 (en) * 1996-09-17 2001-02-27 National Systems Corporation Method and apparatus for creating and using dynamic universal resource locators
US6544295B1 (en) 1996-11-18 2003-04-08 Starfish Software, Inc. Methods for managing preferred internet sites in a computer system having a browser
US6963923B1 (en) * 1997-02-10 2005-11-08 International Business Machines Corporation Method for file transfer restarts using standard internet protocol
US6128663A (en) * 1997-02-11 2000-10-03 Invention Depot, Inc. Method and apparatus for customization of information content provided to a requestor over a network using demographic information yet the user remains anonymous to the server
US6321308B1 (en) * 1997-03-21 2001-11-20 Emc Corporation Method and apparatus for managing access requests from a plurality of devices using dual level queue locking scheme and a doubly-linked circular queue
US5999882A (en) 1997-06-04 1999-12-07 Sterling Software, Inc. Method and system of providing weather information along a travel route
US7058720B1 (en) * 1997-06-30 2006-06-06 Microsoft Corporation Geographical client distribution methods, systems and computer program products
US6122658A (en) * 1997-07-03 2000-09-19 Microsoft Corporation Custom localized information in a networked server for display to an end user
US6038601A (en) * 1997-07-21 2000-03-14 Tibco, Inc. Method and apparatus for storing and delivering documents on the internet
WO1999016226A1 (en) 1997-09-22 1999-04-01 Hughes Electronics Corporation Broadcast delivery newsgroup of information to a personal computer for local storage and access
US5946687A (en) 1997-10-10 1999-08-31 Lucent Technologies Inc. Geo-enabled personal information manager
US6208995B1 (en) 1997-11-24 2001-03-27 International Business Machines Corporation Web browser download of bookmark set
US6310630B1 (en) 1997-12-12 2001-10-30 International Business Machines Corporation Data processing system and method for internet browser history generation
US6122639A (en) 1997-12-23 2000-09-19 Cisco Technology, Inc. Network device information collection and change detection
CA2316256C (en) * 1997-12-24 2009-02-24 America Online, Inc. Localization of clients and servers
US6374336B1 (en) * 1997-12-24 2002-04-16 Avid Technology, Inc. Computer system and process for transferring multiple high bandwidth streams of data between multiple storage units and multiple applications in a scalable and reliable manner
US6415373B1 (en) * 1997-12-24 2002-07-02 Avid Technology, Inc. Computer system and process for transferring multiple high bandwidth streams of data between multiple storage units and multiple applications in a scalable and reliable manner
US6324492B1 (en) * 1998-01-20 2001-11-27 Microsoft Corporation Server stress testing using multiple concurrent client simulation
US6438592B1 (en) * 1998-02-25 2002-08-20 Michael G. Killian Systems for monitoring and improving performance on the world wide web
US5974547A (en) * 1998-03-20 1999-10-26 3Com Corporation Technique for reliable network booting of an operating system to a client computer
EP0948168A1 (en) * 1998-03-31 1999-10-06 TELEFONAKTIEBOLAGET L M ERICSSON (publ) Method and device for data flow control
US6085251A (en) * 1998-04-02 2000-07-04 The United States Of America As Represented By The Secretary Of The Air Force Implementing a parallel file transfer protocol
US6594701B1 (en) * 1998-08-04 2003-07-15 Microsoft Corporation Credit-based methods and systems for controlling data flow between a sender and a receiver with reduced copying of data
US6215769B1 (en) * 1998-10-07 2001-04-10 Nokia Telecommunications, Inc. Enhanced acknowledgment pacing device and method for TCP connections
US6151631A (en) 1998-10-15 2000-11-21 Liquid Audio Inc. Territorial determination of remote computer location in a wide area network for conditional delivery of digitized products
US6442577B1 (en) * 1998-11-03 2002-08-27 Front Porch, Inc. Method and apparatus for dynamically forming customized web pages for web sites
US7260094B1 (en) * 1998-12-22 2007-08-21 Aol Llc Localization of clients and servers
EP1155549B1 (en) * 1999-02-26 2005-04-20 Siemens Aktiengesellschaft Method of transmitting ethernet frames
US6126663A (en) * 1999-04-15 2000-10-03 Hair; John Hunter Expandable bone connector
US7043714B2 (en) * 2001-06-28 2006-05-09 International Business Machines Corporation Method, system, and program for using objects in data stores during execution of a workflow
US20030081582A1 (en) * 2001-10-25 2003-05-01 Nikhil Jain Aggregating multiple wireless communication channels for high data rate transfers
US9229933B2 (en) * 2006-12-19 2016-01-05 International Business Machines Corporation System, method and program for managing file downloads
WO2009032711A1 (en) * 2007-08-29 2009-03-12 Nirvanix, Inc. Policy-based file management for a storage delivery network
CN104780137B (en) * 2014-01-09 2017-04-12 腾讯科技(深圳)有限公司 Data processing method, device and system

Also Published As

Publication number Publication date
US9894139B2 (en) 2018-02-13
DE69829584T2 (en) 2005-09-29
WO1999034555A3 (en) 1999-09-02
ATE292306T1 (en) 2005-04-15
US7617458B1 (en) 2009-11-10
WO1999034555A2 (en) 1999-07-08
US9009345B1 (en) 2015-04-14
DE69829584D1 (en) 2005-05-04
CA2316256A1 (en) 1999-07-08
EP1040431B1 (en) 2005-03-30
US9444875B2 (en) 2016-09-13
AU2093099A (en) 1999-07-19
WO1999034305A1 (en) 1999-07-08
US20100017756A1 (en) 2010-01-21
US20070280229A1 (en) 2007-12-06
EP1040431A1 (en) 2000-10-04
US7962570B2 (en) 2011-06-14
AU1940199A (en) 1999-07-19
US20150195339A1 (en) 2015-07-09
AU1937599A (en) 1999-07-19
WO1999034306A1 (en) 1999-07-08

Similar Documents

Publication Publication Date Title
CA2316256C (en) Localization of clients and servers
KR100733229B1 (en) Geographic data locator
US6363423B1 (en) System and method for remotely generating, assigning and updating network adapter card in a computing system
US6735625B1 (en) System and method for automatically determining whether a product is compatible with a physical device in a network
US7146431B2 (en) Virtual network environment
US6522654B1 (en) Method for hosting the internet protocol suite on the IEEE-1394 high speed serial bus
US5537417A (en) Kernel socket structure for concurrent multiple protocol access
US6775700B2 (en) System and method for common information model object manager proxy interface and management
US6973507B2 (en) Method for resolution services of special domain names
US6041346A (en) Method and system for providing remote storage for an internet appliance
US20030115339A1 (en) Parameter setting system
JPH04299758A (en) Data switching apparatus for communication among software
JPH11511874A (en) Apparatus and method for providing simple and secure management of a remote server
US6311208B1 (en) Server address management system
JP2000003322A (en) Transmission device/method in communication network
US7260094B1 (en) Localization of clients and servers
US6519625B1 (en) Uniform network access
US6970903B1 (en) Distributed component system management using machine-independent activation requests
US6976054B1 (en) Method and system for accessing low-level resources in a network device
US6845397B1 (en) Interface method and system for accessing inner layers of a network protocol
WO2002041122A1 (en) Method for identifying the network location of a computer connected to a computer network
EP1496456A2 (en) Localization of clients and servers
CN114430392A (en) Method and terminal for connecting Intel network card with Switch to expand internet access
US7673053B1 (en) System and method for providing a communications service in distributed computing environment
KR19980037019A (en) Intelligent network opening system for service and its method

Legal Events

Date Code Title Description
EEER Examination request
MKLA Lapsed

Effective date: 20171222