EP2359533B1 - Geolocation mapping of network devices - Google Patents
Geolocation mapping of network devices Download PDFInfo
- Publication number
- EP2359533B1 EP2359533B1 EP09835455.8A EP09835455A EP2359533B1 EP 2359533 B1 EP2359533 B1 EP 2359533B1 EP 09835455 A EP09835455 A EP 09835455A EP 2359533 B1 EP2359533 B1 EP 2359533B1
- Authority
- EP
- European Patent Office
- Prior art keywords
- client
- landmark
- servers
- network
- network client
- 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.)
- Active
Links
- 238000013507 mapping Methods 0.000 title description 4
- 239000000523 sample Substances 0.000 claims description 43
- 238000000034 method Methods 0.000 claims description 31
- 238000012546 transfer Methods 0.000 claims description 3
- 238000010586 diagram Methods 0.000 description 21
- 230000008569 process Effects 0.000 description 16
- 238000005259 measurement Methods 0.000 description 13
- 238000004891 communication Methods 0.000 description 8
- 230000001934 delay Effects 0.000 description 8
- 230000006870 function Effects 0.000 description 6
- 238000012423 maintenance Methods 0.000 description 5
- 230000001413 cellular effect Effects 0.000 description 3
- 230000003993 interaction Effects 0.000 description 3
- 230000006855 networking Effects 0.000 description 3
- 238000012360 testing method Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 1
- 230000009193 crawling Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002250 progressing effect Effects 0.000 description 1
- 230000035899 viability Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
- H04W4/029—Location-based management or tracking services
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/12—Discovery or management of network topologies
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/52—Network services specially adapted for the location of the user terminal
Definitions
- Geographic location information may be used to provide location specific content, to perform network load balancing, or to provide demographic information.
- Location specific content may include providing local weather information, localizing content by providing language- and/or country-specific interfaces, providing selective access based on location, etc.
- Geolocation may assist in network load balancing by routing data traffic to servers geographically closer to the users. Demographic information of user locations may be used for marketing and planning purposes.
- a client may be any user, server, or other network device which is connected to a network.
- a landmark is any network device with a known geolocation which is used as a reference point.
- An assisted global positioning system receiver associated with the device uses a received communication from the server for interacting with the global positioning system. An indication of this interaction is used for making an actual device location determination.
- Patent Application US 2004/0190448 describes a system where the IP address of the user allows the system to determine whether user traffic data collected logically corresponds to the known geographic region of the IP address.
- Patent application US 2008/0032706 describes a system where times of reception of signals from cellular base stations are measured at mobile cellular phone. This timing data may then be used to estimate a location of mobile cellular telephone.
- RCIRs richly-connected internet regions
- MCIRs moderately-connected internet regions
- AS moderate inter-autonomous system
- This disclosure describes providing geolocation information of a client in a MCIR or a RCIR using a closest-shortest ("CS") rule.
- the CS rule uses the observation that the shortest delay comes from the closest physical distance.
- a coordination server maintains a list of landmark servers.
- the landmark servers have known geographic locations and are known to have responded to probes in the past. Landmarks need not be actively maintained or administered by the coordination server, or even necessarily by the same entity owning the coordination server, and thus may be considered passive.
- a network client may execute an application, script, or other process which establishes communication with the coordination server.
- the coordination server determines a general region in which the client is located by analyzing a network address of the client, and provides a list of area landmarks in that region to the client.
- the client then probes the area landmark servers and sends delay results back to the coordination server.
- the coordination server uses the CS rule to determine the area of the region in which the client is located, and provides a list of city servers within the determined area.
- the coordination server provides the city servers to the client, which then probes the city servers. Increasing the number of landmarks probed may increase accuracy. Probe results are transmitted to the coordination server, which then uses the delay information as interpreted by the CS rule to determine the geolocation of the client. Use of the CS rule in probing provides better accuracy in MCIRs over delay based triangulation because networking delays are not translated into erroneous physical distance measurements.
- FIG. 1 is a diagram of an illustrative network encompassing a region 100. Regions are larger geographic areas, for example, continents, countries, global hemispheres, etc.
- a client 102 is located within a center city 104.
- a "center city” is considered to be the center or an area.
- a center city may be a geographic center, center from a networking delay standpoint, or combination of the two.
- landmark servers 106A, 106B, and 106C Within the geographic boundaries of center city 104 are landmark servers 106A, 106B, and 106C. Center city 104 is located within geographic area 108. Also within area 108 are cities 110 and 112. Within city 110 is landmark server 114.
- center city 116 located within area 118.
- landmarks servers 120A, 120B, and 120C are also located within area 118.
- City 122 is also located within area 118. In the illustrated example, both areas 108 and 118 are located within the region 100.
- Coordination server 124 and application server 126 are shown outside of areas 108 and 118. However, coordination server 124 and application server 126 may be located in the same or different locations, and may be within an area or city.
- the coordination server To determine a geolocation of the client, the coordination server first determines a region based on the network address from the client 102.
- the coordination server 124 provides to the client 102 a list of landmark servers in one or more areas in the region.
- the client 102 probes 128A area landmark server 120A in area 118 and then probes 128B area landmark server 106A located in area 108.
- Probe delay results are provided 130 to the coordination server 124 which determines the area using the CS rule. That is, the area level landmark server having the shortest communication delay is determined to be closest to the client 102.
- the absolute value of the delay is not itself considered significant, but rather the relative ranking of the delay results.
- the coordination server 124 may then provide a list of city-level landmark servers within the determined area to client 102 for probing.
- the client 102 may then probe 132A city landmark server 106C and then probe 132B landmark server 114 located in city 110.
- Probe delay results are provided 130 to the coordination server 124, which then determines 134 geolocation of the client again using the CS rule.
- the city level landmark server having the shortest communication delay is determined to be closest to the client 102.
- the client 102 may be determined to be located in the city in which the city level landmark server having the shortest delay is located.
- the coordination server 124 may then provide geolocation information to the application server 126 which may then serve content 136 tailored to the location of the client 102.
- FIG. 2 is a flow diagram of an illustrative process using the closest-shortest rule to determine geolocation.
- a client measures a time delay for data sent between the client and one or more landmark servers by probing the landmark servers to produce probe results.
- the probing may comprise an Internet Control Message Protocol (ICMP) packet, a Hypertext Transfer Protocol/Get (HTTP/Get request), or other interrogation which elicits a response from a landmark server.
- ICMP Internet Control Message Protocol
- HTTP/Get provides the advantage of being relatively easy to implement in scripting languages such as JavaScriptTM and ECMAScript, and may provide a better response than ICMP.
- the time delay may either be round-trip, or one way. Generally, increasing the number of landmark servers probed results in increased accuracy of the resulting geolocation.
- probe results are ranked based on the magnitude of the delay producing ranked measurements. For example, the results may be ranked with the probe result having a lowest delay magnitude having a rank of 0.
- N may be any predetermined threshold value. For example, if one hundred probes are made, N may be five. Thus, the five probe results having the lowest delays will be selected.
- the N lowest delay measurements are compared against the geolocation of the landmark servers producing those lowest delay measurements.
- the closest-shortest rule assumes that the geographically closest landmark servers will have the shortest delay time to respond to a client.
- the location of the client is estimated, for example, as being in the same city as the probe result measurement with the lowest delay time.
- FIG. 3 is a schematic diagram of an illustrative network 300 showing servers and relative distances to illustrate the closest-shortest rule.
- a city 304 Inside an area 302 resides a city 304. Areas and cities may be any convenient bounded geographic area, for example a political subdivision such as a state or province, statistical survey areas, etc. Areas and cities are within regions.
- Client 306 connects via link 308 having a delay "D" of 1 to local area network (LAN) switch 310.
- D indicates a time delay, for example, measured in milliseconds (ms).
- Server 312 is also within city 304 and connects via link 314 which also has a delay of 1 to LAN switch 310. These delays are typically short because client 306 and server 312 are on the same physical subnetwork and communicate directly with the LAN switch 310.
- LAN switch 310 connects via link 316 having a delay of 200 to router 318 which is also within city 304.
- Server 320 also within city 304 connects via link 322 having a delay of 50 to router 318.
- Router 318 in city 304 connects via link 324 having a delay of 900 and travels across mountains 326 to server 328 located within city 330, which is also within area 302.
- Router 318 in city 304 also connects via link 332 which has a delay of 11,000 and travels across ocean 334 to router 336.
- Router 336 is located within city 338 which is inside area 340. Within city 338, router 336 connects via link 342 having a delay of 50 to client 344. Also within city 338, router 336 connects via link 346 having a delay of 100 to server 348.
- a summation of delays between various nodes in the network illustrates the shortest-closest rule.
- Table 1 shows the summation of one-way delays between client 306 and various points in the network.
- TABLE 1 START AREA CITY DESTINATION AREA CITY SUM OF DELAY (ONE-WAY) 306 302 304 312 302 304 2 306 302 304 318 302 304 201 306 302 304 320 302 304 251 306 302 304 328 302 330 1101 306 302 304 344 340 338 11251 306 302 304 348 340 338 11301
- the closest-shortest rule can be used to determine the likely area and city within which client 306 resides using known geolocations of servers, such as landmark servers. For example, client 306 probes all servers shown to determine delays. The results are shown in Table 2. TABLE 2 START DESTINATION AREA CITY SUM OF DELAY (ONE-WAY) RANK 306 312 302 304 2 0 306 320 302 304 251 1 306 328 302 330 1101 2 306 348 340 338 11301 3
- N the number of ranked measurements
- ranked items 0 and 1 are selected. These two entries are in area 302, and thus using the closest shortest rule, it is assumed that client 306 is geographically within area 302. Unlike delay based triangulation which are prone to errors in MICRs, use of the CS rule provides greater accuracy.
- the process may be repeated using a set of servers within a known area to further identify the city of the client using servers in cities within the area.
- FIG. 4 is an illustrative diagram of a coordination server 124.
- Coordination server 124 may be a single server, distributed environment such as a cluster, virtual server, etc.
- Coordination server 124 may comprise one or multiple databases and engines.
- modules and engines may be implemented using software, hardware, firmware, or a combination of these.
- the modules and engines are implemented using software including instructions stored on a computer readable storage medium or otherwise in memory and executable on a processor.
- a landmark database 402 stores the information of landmark servers used, including their network addresses, geolocations, as well as status information such as timeout errors reported by clients.
- Network addresses may include internet protocol ("IP”) address, for example.
- a measurement result database 404 stores both area-level and city-level measurement results, including the network addresses of the client and the corresponding landmark servers probed, as well as the measured delays.
- a location result database 406 stores geographical mapping results of clients, including the network addresses of clients and corresponding cities in which the network addresses are determined to be located.
- a landmark maintenance engine 408 may comprise several functions. Because the conditions of the landmark servers continuously change, the landmark maintenance engine 408 dynamically maintains the list of landmark servers in the landmark database 402. These functions are discussed in more depth below, but include building prospective landmark server lists 410, testing prospective landmark server lists 412, and maintaining landmark server lists 414.
- a landmark selection engine 416 may comprise several functions. These include selecting area landmark servers 418 and selecting city-level landmark servers 420 for clients upon request. These functions are discussed in more depth below.
- a measurement result processing engine 422 may comprise several functions. These include processing and storing client measurement results 424 in the measurement result database 404 and storing landmark timeouts 426 to the landmark database 402.
- a map engine 428 may comprise several functions. These include using the closest-shortest rule to determine the geolocation of a client 430 and storing mapping results 432 in a location results database 406.
- FIG. 5 is a flow diagram showing details of an illustrative process of building the prospective landmark server list 410.
- a web server is discovered. While web servers are mentioned herein, other types of servers may be used, for example mail servers. This discovery may occur as a result of web crawling, port scans, etc.
- an IP address of the server is determined.
- a location agreement threshold is set. This threshold is used to determine how many other geolocation databases must agree for a geolocation of a server to be considered valid. For example, when the LAT is set to ⁇ 3, then three or more geolocation databases must report a server as being at substantially the same location before the geolocation is accepted as being valid for use in the landmark server list.
- a geolocation of the server discovered in 502 is made using conventional geolocation mapping databases or services.
- the landmark maintenance engine 408 determines whether the LAT has been reached. When the LAT is reached and multiple servers report substantially the same location for the server discovered in 502, the server is added 512 to the prospective landmark server list. If the LAT is not met, at 514, the server is tagged as unsuitable. Unsuitable servers may be tested again at a later date, where desired.
- FIG. 6 is a flow diagram of an illustrative process of testing prospective landmark servers 412.
- a server is selected from a prospective landmark server list.
- a variance viability threshold (VVT) is set. This threshold determines the acceptable level of variance between results of different probing techniques. For example, where ICMP and HTTP/Get probes are used, this variance may specify that the ICMP and HTTP/Get measurements must be within a specific percentage or absolute value of one another. While ICMP and HTTP/Get probes are described, other interrogation methods may additionally or alternatively be used.
- the server is probed using an ICMP packet.
- the server is probed using HTTP/Get.
- the ICMP and HTTP/Get probes are compared.
- a determined is made as to whether the ICMP and HTTP/Get probes are within the VVT.
- the prospective landmark server is added to the landmark server list at 614.
- the server is tagged as unsuitable at 616. Unsuitable servers may be tested again at a later date, where desired.
- FIG. 7 is a flow diagram of an illustrative process of selecting area landmark servers for a client 418 at a coordination server 124.
- the coordination server 124 receives a network address and autonomous system number from a client.
- a list of center cities not probed by the client designated CSET 1 is generated.
- a quantity of landmarks selected for probing is set and designed M1.
- one or more landmark servers are selected for each city in CSET1.
- the selection of landmark servers at 708 comprises two steps. At 710, landmark servers in center cities within the same autonomous system are determined and designated group LC1. At 712, landmark servers in center cities within different autonomous systems are determined and designated group LC0.
- FIG. 8 is a flow diagram illustrating selecting city-level landmark servers 420 for a client.
- a list CSET2 of center cities not probed by the client in the area is generated.
- the number of landmarks selected for probing is set and designated M2.
- landmark servers are selected for each city in CSET2.
- the selection of landmark servers in 806 comprises two steps. At 808, landmark servers in cities within the same autonomous system are determined and designated LC1. At 810, landmark servers in cities with different autonomous systems are determined and designated LC0.
- FIG. 9 is a flow diagram showing an illustrative process of client probing 900.
- the client 102 gets area-level landmarks from a coordination server.
- the client probes the area-level landmarks obtained from the coordination server to determine delay between the client 102 and each of the area-level landmark servers.
- the client sends first, area-level results to the coordination server.
- the first results include a relative magnitude of communication delay between the client and each of the area-level landmark servers.
- the client gets city-level landmarks from the coordination server.
- the client probes the city-level landmarks obtained from the coordination server to determine delay between the client and the city-level landmark servers.
- the client sends second, city-level results to the coordination server.
- the second results include a relative magnitude of communication delay between the client and each of the city-level landmark servers.
- FIG. 10 is a flow diagram showing other illustrative coordination server activities in conjunction with a client and associated client probes.
- the coordination server gets a request for area-level landmarks from a client.
- the coordination server determines a region in which the client is located. The region determination may be made by using a previously established list of network addresses and their corresponding geolocation.
- the coordination server selects a list of area landmark servers.
- the coordination server provides this list of area-level landmarks to the client.
- the coordination server receives the area-level probe results from the client.
- the coordination server processes area-level results to determine the area(s) closest to the client using the closest-shortest rule to determine area(s) based on communication delay between the client and the area-level landmark servers.
- the coordination server selects a list of city-level landmark servers.
- the coordination server provides the list of city-level landmark servers to the client.
- the coordination server receives the city-level probe results from the client.
- the coordination server processes city-level results to determine geolocation of the client using the closest-shortest rule based on communication delay between the client and the city-level landmark servers.
- FIG. 11 shows illustrative flow of information and interaction between a client 102, an application server 126, a coordination server 124, and landmark servers 1112 and 1118.
- time increases while progressing down the page, as indicated by arrow 1102.
- An application server provides a web page with a geolocation script 1104 to a client 102.
- the script executing on the client 102 requests 1106 an area landmark server list from the coordination server 124.
- the coordination server 124 then provides 1108 an area landmark server list to the client 102.
- the client 102 then probes 1110 area landmark servers 1112.
- Client 102 then provides 1114 area-level results to coordination server 124.
- Coordination server 124 then provides 1116 a city landmark server list to the client 102.
- the client 102 then probes 1118 city landmark servers 1120.
- Client 102 then provides 1122 city-level results to coordination server 124.
- Coordination server 124 determines geolocation based on these results, and provides 1124 the geolocation information to the application server 126.
- CRSM computer-readable storage media
- CRSM may include, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computing device
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer And Data Communications (AREA)
- Information Transfer Between Computers (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
- Mobile Radio Communication Systems (AREA)
Description
- Internet service operators such as e-commerce, media outlets, information providers, etc., benefit from knowing the geographic location of their users. Geographic location ("geolocation") information may be used to provide location specific content, to perform network load balancing, or to provide demographic information..
- Location specific content may include providing local weather information, localizing content by providing language- and/or country-specific interfaces, providing selective access based on location, etc. Geolocation may assist in network load balancing by routing data traffic to servers geographically closer to the users. Demographic information of user locations may be used for marketing and planning purposes.
- Existing geolocation services suffer from errors, maintenance, performance, and reliability problems, particularly in regions with rapidly growing networks. In regions with rapidly growing networks, given the distributed and highly variable nature of the internet, delay-based geolocation methods using triangulation are inaccurate. Delay-based systems rely on an assumption that a linear correlation exists between networking delay and the distance between a client and a landmark. These delays are then used to triangulate the approximate position of the client. A client may be any user, server, or other network device which is connected to a network. A landmark is any network device with a known geolocation which is used as a reference point. Patent application
US 2007/0182631 describes a system for determining a device location. An assisted global positioning system receiver associated with the device, uses a received communication from the server for interacting with the global positioning system. An indication of this interaction is used for making an actual device location determination. Patent ApplicationUS 2004/0190448 describes a system where the IP address of the user allows the system to determine whether user traffic data collected logically corresponds to the known geographic region of the IP address. Patent applicationUS 2008/0032706 describes a system where times of reception of signals from cellular base stations are measured at mobile cellular phone. This timing data may then be used to estimate a location of mobile cellular telephone. - In richly-connected internet regions (RCIRs), for example North America and Western Europe, the assumption of a high correlation between delay and distance may provide useful data for triangulation methods. However, in moderately-connected internet regions (MCIRs), for example developing nations, this assumption breaks down and the correlation is no longer valid. Factors contributing to this include network congestion, circuitous paths, moderate inter-autonomous system (AS) connections, etc. Thus, in MCIRs, the delay between a client and a landmark does not sufficiently correlate with the physical distance between the client and landmark to enable usably accurate triangulation based geolocation.
- The invention is disclosed by
method claim 1 and system claim 7. Further embodiments are described by the dependent claims. As described above, regions with rapidly growing networks are particularly susceptible suffer from errors, maintenance, performance, and reliability problems. - This disclosure describes providing geolocation information of a client in a MCIR or a RCIR using a closest-shortest ("CS") rule. The CS rule uses the observation that the shortest delay comes from the closest physical distance.
- In one aspect, a coordination server maintains a list of landmark servers. The landmark servers have known geographic locations and are known to have responded to probes in the past. Landmarks need not be actively maintained or administered by the coordination server, or even necessarily by the same entity owning the coordination server, and thus may be considered passive.
- A network client ("client") may execute an application, script, or other process which establishes communication with the coordination server. The coordination server determines a general region in which the client is located by analyzing a network address of the client, and provides a list of area landmarks in that region to the client. The client then probes the area landmark servers and sends delay results back to the coordination server. The coordination server then uses the CS rule to determine the area of the region in which the client is located, and provides a list of city servers within the determined area. The coordination server provides the city servers to the client, which then probes the city servers. Increasing the number of landmarks probed may increase accuracy. Probe results are transmitted to the coordination server, which then uses the delay information as interpreted by the CS rule to determine the geolocation of the client. Use of the CS rule in probing provides better accuracy in MCIRs over delay based triangulation because networking delays are not translated into erroneous physical distance measurements.
- The disclosure is made with reference to the accompanying figures. In the figures, the left most reference number digit identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical terms.
-
FIG. 1 is a diagram of an illustrative network having landmark servers and a coordination server gathering probe data from a client to determine geolocation. -
FIG. 2 is a flow diagram of an illustrative process using the closest-shortest rule to determine geolocation. -
FIG. 3 is a diagram of an illustrative network showing servers and relative distances to illustrate the closest-shortest rule. -
FIG. 4 is a diagram of an illustrative coordination server. -
FIG. 5 is a flow diagram of an illustrative process of building a prospective landmark server list. -
FIG. 6 is a flow diagram of an illustrative process of testing the prospective landmark servers. -
FIG. 7 is a flow diagram of an illustrative process of selecting area landmark servers for a client. -
FIG. 8 is a flow diagram of an illustrative process of selecting city-level landmark servers for a client. -
FIG. 9 is a flow diagram of an illustrative process of client probing. -
FIG. 10 is a flow diagram of an illustrative process of coordinating server activities in conjunction with client probes. -
FIG. 11 shows an illustrative flow of information and interaction between a client, an application server, a coordination server, and landmark servers. -
FIG. 1 is a diagram of an illustrative network encompassing aregion 100. Regions are larger geographic areas, for example, continents, countries, global hemispheres, etc. Aclient 102 is located within acenter city 104. A "center city" is considered to be the center or an area. A center city may be a geographic center, center from a networking delay standpoint, or combination of the two. Within the geographic boundaries ofcenter city 104 arelandmark servers city 104 is located withingeographic area 108. Also withinarea 108 arecities city 110 islandmark server 114. - Also shown is
center city 116 located withinarea 118. Withincenter city 116 arelandmarks servers City 122 is also located withinarea 118. In the illustrated example, bothareas region 100. -
Coordination server 124 andapplication server 126 are shown outside ofareas coordination server 124 andapplication server 126 may be located in the same or different locations, and may be within an area or city. - To determine a geolocation of the client, the coordination server first determines a region based on the network address from the
client 102. Thecoordination server 124 provides to the client 102 a list of landmark servers in one or more areas in the region. In the illustrated example, theclient 102probes 128Aarea landmark server 120A inarea 118 and then probes 128B area landmark server 106A located inarea 108. Probe delay results are provided 130 to thecoordination server 124 which determines the area using the CS rule. That is, the area level landmark server having the shortest communication delay is determined to be closest to theclient 102. The absolute value of the delay is not itself considered significant, but rather the relative ranking of the delay results. Thecoordination server 124 may then provide a list of city-level landmark servers within the determined area toclient 102 for probing. Theclient 102 may then probe 132Acity landmark server 106C and then probe132B landmark server 114 located incity 110. Probe delay results are provided 130 to thecoordination server 124, which then determines 134 geolocation of the client again using the CS rule. At this stage, the city level landmark server having the shortest communication delay is determined to be closest to theclient 102. In fact, in some implementations, theclient 102 may be determined to be located in the city in which the city level landmark server having the shortest delay is located. - The
coordination server 124 may then provide geolocation information to theapplication server 126 which may then servecontent 136 tailored to the location of theclient 102. -
FIG. 2 is a flow diagram of an illustrative process using the closest-shortest rule to determine geolocation. At 202, a client measures a time delay for data sent between the client and one or more landmark servers by probing the landmark servers to produce probe results. The probing may comprise an Internet Control Message Protocol (ICMP) packet, a Hypertext Transfer Protocol/Get (HTTP/Get request), or other interrogation which elicits a response from a landmark server. HTTP/Get provides the advantage of being relatively easy to implement in scripting languages such as JavaScript™ and ECMAScript, and may provide a better response than ICMP. The time delay may either be round-trip, or one way. Generally, increasing the number of landmark servers probed results in increased accuracy of the resulting geolocation. - At 204, probe results are ranked based on the magnitude of the delay producing ranked measurements. For example, the results may be ranked with the probe result having a lowest delay magnitude having a rank of 0.
- At 206, the N lowest ranked measurements are selected. N may be any predetermined threshold value. For example, if one hundred probes are made, N may be five. Thus, the five probe results having the lowest delays will be selected.
- At 208, the N lowest delay measurements are compared against the geolocation of the landmark servers producing those lowest delay measurements. The closest-shortest rule assumes that the geographically closest landmark servers will have the shortest delay time to respond to a client. Thus the location of the client is estimated, for example, as being in the same city as the probe result measurement with the lowest delay time.
-
FIG. 3 is a schematic diagram of anillustrative network 300 showing servers and relative distances to illustrate the closest-shortest rule. Inside an area 302 resides acity 304. Areas and cities may be any convenient bounded geographic area, for example a political subdivision such as a state or province, statistical survey areas, etc. Areas and cities are within regions. - Within
city 304 is aclient 306.Client 306 connects vialink 308 having a delay "D" of 1 to local area network (LAN)switch 310. For the purposes of this illustration "D" indicates a time delay, for example, measured in milliseconds (ms).Server 312 is also withincity 304 and connects vialink 314 which also has a delay of 1 toLAN switch 310. These delays are typically short becauseclient 306 andserver 312 are on the same physical subnetwork and communicate directly with theLAN switch 310. -
LAN switch 310 connects vialink 316 having a delay of 200 torouter 318 which is also withincity 304.Server 320, also withincity 304 connects vialink 322 having a delay of 50 torouter 318. -
Router 318 incity 304 connects vialink 324 having a delay of 900 and travels acrossmountains 326 toserver 328 located withincity 330, which is also within area 302. -
Router 318 incity 304 also connects vialink 332 which has a delay of 11,000 and travels acrossocean 334 torouter 336.Router 336 is located within city 338 which is insidearea 340. Within city 338,router 336 connects vialink 342 having a delay of 50 toclient 344. Also within city 338,router 336 connects vialink 346 having a delay of 100 toserver 348. - A summation of delays between various nodes in the network illustrates the shortest-closest rule. Table 1 shows the summation of one-way delays between
client 306 and various points in the network.TABLE 1 START AREA CITY DESTINATION AREA CITY SUM OF DELAY (ONE-WAY) 306 302 304 312 302 304 2 306 302 304 318 302 304 201 306 302 304 320 302 304 251 306 302 304 328 302 330 1101 306 302 304 344 340 338 11251 306 302 304 348 340 338 11301 - The closest-shortest rule can be used to determine the likely area and city within which
client 306 resides using known geolocations of servers, such as landmark servers. For example,client 306 probes all servers shown to determine delays. The results are shown in Table 2.TABLE 2 START DESTINATION AREA CITY SUM OF DELAY (ONE-WAY) RANK 306 312 302 304 2 0 306 320 302 304 251 1 306 328 302 330 1101 2 306 348 340 338 11301 3 - When the N lowest ranked measurements are selected, where N=2, ranked
items 0 and 1 are selected. These two entries are in area 302, and thus using the closest shortest rule, it is assumed thatclient 306 is geographically within area 302. Unlike delay based triangulation which are prone to errors in MICRs, use of the CS rule provides greater accuracy. The process may be repeated using a set of servers within a known area to further identify the city of the client using servers in cities within the area. -
FIG. 4 is an illustrative diagram of acoordination server 124.Coordination server 124 may be a single server, distributed environment such as a cluster, virtual server, etc.Coordination server 124 may comprise one or multiple databases and engines. As described in this application, modules and engines may be implemented using software, hardware, firmware, or a combination of these. In the illustrated example, the modules and engines are implemented using software including instructions stored on a computer readable storage medium or otherwise in memory and executable on a processor. - In the illustrated example, a
landmark database 402 stores the information of landmark servers used, including their network addresses, geolocations, as well as status information such as timeout errors reported by clients. Network addresses may include internet protocol ("IP") address, for example. - A
measurement result database 404 stores both area-level and city-level measurement results, including the network addresses of the client and the corresponding landmark servers probed, as well as the measured delays. - A
location result database 406 stores geographical mapping results of clients, including the network addresses of clients and corresponding cities in which the network addresses are determined to be located. - A
landmark maintenance engine 408 may comprise several functions. Because the conditions of the landmark servers continuously change, thelandmark maintenance engine 408 dynamically maintains the list of landmark servers in thelandmark database 402. These functions are discussed in more depth below, but include building prospective landmark server lists 410, testing prospective landmark server lists 412, and maintaining landmark server lists 414. - A
landmark selection engine 416 may comprise several functions. These include selectingarea landmark servers 418 and selecting city-level landmark servers 420 for clients upon request. These functions are discussed in more depth below. - A measurement
result processing engine 422 may comprise several functions. These include processing and storing client measurement results 424 in themeasurement result database 404 and storinglandmark timeouts 426 to thelandmark database 402. - A
map engine 428 may comprise several functions. These include using the closest-shortest rule to determine the geolocation of aclient 430 and storingmapping results 432 in alocation results database 406. -
FIG. 5 is a flow diagram showing details of an illustrative process of building the prospectivelandmark server list 410. At 502, a web server is discovered. While web servers are mentioned herein, other types of servers may be used, for example mail servers. This discovery may occur as a result of web crawling, port scans, etc. At 504, an IP address of the server is determined. - At 506, a location agreement threshold (LAT) is set. This threshold is used to determine how many other geolocation databases must agree for a geolocation of a server to be considered valid. For example, when the LAT is set to ≥ 3, then three or more geolocation databases must report a server as being at substantially the same location before the geolocation is accepted as being valid for use in the landmark server list.
- At 508, a geolocation of the server discovered in 502 is made using conventional geolocation mapping databases or services.
- At 510, the
landmark maintenance engine 408 determines whether the LAT has been reached. When the LAT is reached and multiple servers report substantially the same location for the server discovered in 502, the server is added 512 to the prospective landmark server list. If the LAT is not met, at 514, the server is tagged as unsuitable. Unsuitable servers may be tested again at a later date, where desired. -
FIG. 6 is a flow diagram of an illustrative process of testingprospective landmark servers 412. At 602, a server is selected from a prospective landmark server list. At 604, a variance viability threshold (VVT) is set. This threshold determines the acceptable level of variance between results of different probing techniques. For example, where ICMP and HTTP/Get probes are used, this variance may specify that the ICMP and HTTP/Get measurements must be within a specific percentage or absolute value of one another. While ICMP and HTTP/Get probes are described, other interrogation methods may additionally or alternatively be used. - At 606, the server is probed using an ICMP packet. At 608, the server is probed using HTTP/Get. At 610, the ICMP and HTTP/Get probes are compared. At 612, a determined is made as to whether the ICMP and HTTP/Get probes are within the VVT. When the probes are within the VVT, the prospective landmark server is added to the landmark server list at 614. When the probes are not within the VVT, the server is tagged as unsuitable at 616. Unsuitable servers may be tested again at a later date, where desired.
-
FIG. 7 is a flow diagram of an illustrative process of selecting area landmark servers for aclient 418 at acoordination server 124. At 702, thecoordination server 124 receives a network address and autonomous system number from a client. At 704, a list of center cities not probed by the client designatedCSET 1 is generated. At 706, a quantity of landmarks selected for probing is set and designed M1. At 708, for each city in CSET1, one or more landmark servers are selected. - The selection of landmark servers at 708 comprises two steps. At 710, landmark servers in center cities within the same autonomous system are determined and designated group LC1. At 712, landmark servers in center cities within different autonomous systems are determined and designated group LC0.
- At 714, a determination is made and where |LC1| ≥ M1, then at 716 M1 landmarks are randomly selected from LC1 to form a first set of landmark servers LSET1. When |LC1| < M1, at 718, (M1 - |LC1|) landmark servers are randomly selected from LC0, and LC1 and LC2 are joined to form LSET1.
-
FIG. 8 is a flow diagram illustrating selecting city-level landmark servers 420 for a client. At 802, a list CSET2 of center cities not probed by the client in the area is generated. At 804, the number of landmarks selected for probing is set and designated M2. At 806, for each city in CSET2, landmark servers are selected. - The selection of landmark servers in 806 comprises two steps. At 808, landmark servers in cities within the same autonomous system are determined and designated LC1. At 810, landmark servers in cities with different autonomous systems are determined and designated LC0.
- At 812, a determination is made and where |LC1| ≥ M2, at 814 M2 landmarks are randomly selected from LC1 to form a second set of landmark servers LSET2. When |LC1|< M2, at 816, (M2-|LC1|) landmark servers are randomly selected from LC0, and LC1 and LC2 are joined to form LSET2.
-
FIG. 9 is a flow diagram showing an illustrative process of client probing 900. At 902, theclient 102 gets area-level landmarks from a coordination server. At 904, the client probes the area-level landmarks obtained from the coordination server to determine delay between theclient 102 and each of the area-level landmark servers. At 906, the client sends first, area-level results to the coordination server. The first results include a relative magnitude of communication delay between the client and each of the area-level landmark servers. - At 908, the client gets city-level landmarks from the coordination server. At 910, the client probes the city-level landmarks obtained from the coordination server to determine delay between the client and the city-level landmark servers. At 912, the client sends second, city-level results to the coordination server. The second results include a relative magnitude of communication delay between the client and each of the city-level landmark servers.
-
FIG. 10 is a flow diagram showing other illustrative coordination server activities in conjunction with a client and associated client probes. At 1002, the coordination server gets a request for area-level landmarks from a client. At 1004, the coordination server determines a region in which the client is located. The region determination may be made by using a previously established list of network addresses and their corresponding geolocation. - At 1006, the coordination server selects a list of area landmark servers. At 1008, the coordination server provides this list of area-level landmarks to the client. At 1010, the coordination server receives the area-level probe results from the client.
- At 1012, the coordination server processes area-level results to determine the area(s) closest to the client using the closest-shortest rule to determine area(s) based on communication delay between the client and the area-level landmark servers.
- At 1014, the coordination server selects a list of city-level landmark servers. At 1016, the coordination server provides the list of city-level landmark servers to the client. At 1018, the coordination server receives the city-level probe results from the client.
- At 1020, the coordination server processes city-level results to determine geolocation of the client using the closest-shortest rule based on communication delay between the client and the city-level landmark servers.
-
FIG. 11 shows illustrative flow of information and interaction between aclient 102, anapplication server 126, acoordination server 124, andlandmark servers arrow 1102. - An application server provides a web page with a
geolocation script 1104 to aclient 102. The script executing on theclient 102 then requests 1106 an area landmark server list from thecoordination server 124. Thecoordination server 124 then provides 1108 an area landmark server list to theclient 102. Theclient 102 then probes 1110area landmark servers 1112. -
Client 102 then provides 1114 area-level results tocoordination server 124.Coordination server 124 then provides 1116 a city landmark server list to theclient 102. Theclient 102 then probes 1118city landmark servers 1120. -
Client 102 then provides 1122 city-level results tocoordination server 124.Coordination server 124 determines geolocation based on these results, and provides 1124 the geolocation information to theapplication server 126. - Although specific details of exemplary methods are described with regard to the figures and other flow diagrams presented herein, it should be understood that certain acts shown in the figures need not be performed in the order described, and may be modified, and/or may be omitted entirely, depending on the circumstances. Moreover, the acts and methods described may be implemented by a computer, processor or other computing device based on instructions stored on one or more computer-readable storage media. The computer-readable storage media (CRSM) may be any available physical media that can be accessed by a computing device to implement the instructions stored thereon. CRSM may include, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computing device
Claims (10)
- A method of determining a geographic location of a network client, the method comprising:receiving a request from a network client (102) at a coordination server (124); anddetermining at the coordination server (124) a geographic location of the network client (102) using probe information gathered by the network client (102);wherein the probe information comprises delay data for traffic between the network client (102) and a landmark server (106A, 106B, 106C, 120A, a20B, 120C);wherein landmark servers have a known geographic location;wherein the determining the geographic location comprises:determining a region (100) based on a network address of the network client (102);probing a first set of landmark servers (120A, 106A) to determine a geographic area within the region (100) based on ranking probe information from the plurality of probes by a relative magnitude of delay of traffic between the network client (102) and the first set of landmark servers (120A, 106A); andprobing a second set of landmark servers (106C, 114) located within the determined geographic area (108) to determine a city in which the network client (102) is located based on ranking probe information from the plurality of probes by a relative magnitude of delay of traffic between the network client (102) and the second set of landmark servers (106C, 114).
- The method according to claim 1, wherein a script executing within an internet browser initiates probes to gather the probe information.
- The method according to any one of claims 1-2, wherein the probe information is gathered using a Hypertext transfer protocol/Get (HTTP/Get) request or Internet Control Message Protocol (ICMP) request initiated by the network client.
- The method of claim 1, wherein the first set of landmark servers (120A, 106A) located in the determined region (100) is randomly selected from a list of available landmark servers (120A, 120B, 120C, 106A, 106B, 106C, 114) located in the determined region and the second set of landmark servers (106A, 106B, 106C, 114) is randomly selected from a list of available landmark servers located within the determined geographic area (108).
- The method according to any one of claims 1 or 4, wherein the landmark servers are passive.
- The method according to any one of claims 1-5, wherein the method is stored on a computer-readable storage medium.
- A system for determining a geographic location of a network client (102), the system comprising:an application server (126) connected to a network and configured to deliver a probing module to a client (102) on the network, the probing module configured to execute on the client and interrogate one or more landmark servers and collect delay data; anda coordination server (124) connected to a network and configured to determine a geographic location of the client using the delay data received from the probing module;wherein landmark servers have a known geographic location;wherein the coordination server (124) is configured to determine a geographic location of the network client (102) by:determining a region (100) in which the client (102) is located based on the network address of the network client;configuring the probing module to probe a first set of landmark servers (120A, 106A) in the region (100) to determine a geographic area (108) in which the network client (102) is located, based on ranking the delay data from a plurality of interrogations by the relative magnitude of delay between the network client (102) and the first set of landmark servers (120A, 106A); andconfiguring the probing module to probe a second set of landmark servers (106C, 114) located within the determined geographic area (108) to determine a city in which the network client (102) is located, based on ranking the delay data from a plurality of interrogations by the relative magnitude of delay between the network client (102) and the second set of landmark servers (106C, 114).
- The system of claim7, wherein the probing module comprises a script configured to execute within an internet browser.
- The system according to any one of claims 7-8, wherein the delay data is gathered using a Hypertext transfer protocol/Get (HTTP/Get) request or Internet Control Message Protocol (ICMP) request initiated by the probing module.
- The system of claim 7, wherein determining a region comprises comparing the network client network address with a database of known network address ranges, the database including one or more regions corresponding to each address range.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/336,163 US8180887B2 (en) | 2008-12-16 | 2008-12-16 | Geolocation mapping of network devices |
PCT/US2009/065295 WO2010074857A2 (en) | 2008-12-16 | 2009-11-20 | Geolocation mapping of network devices |
Publications (3)
Publication Number | Publication Date |
---|---|
EP2359533A2 EP2359533A2 (en) | 2011-08-24 |
EP2359533A4 EP2359533A4 (en) | 2017-01-25 |
EP2359533B1 true EP2359533B1 (en) | 2018-12-26 |
Family
ID=42241874
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP09835455.8A Active EP2359533B1 (en) | 2008-12-16 | 2009-11-20 | Geolocation mapping of network devices |
Country Status (4)
Country | Link |
---|---|
US (1) | US8180887B2 (en) |
EP (1) | EP2359533B1 (en) |
CN (1) | CN102246463B (en) |
WO (1) | WO2010074857A2 (en) |
Families Citing this family (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9412123B2 (en) | 2003-07-01 | 2016-08-09 | The 41St Parameter, Inc. | Keystroke analysis |
US10999298B2 (en) | 2004-03-02 | 2021-05-04 | The 41St Parameter, Inc. | Method and system for identifying users and detecting fraud by use of the internet |
US11301585B2 (en) | 2005-12-16 | 2022-04-12 | The 41St Parameter, Inc. | Methods and apparatus for securely displaying digital images |
US8938671B2 (en) | 2005-12-16 | 2015-01-20 | The 41St Parameter, Inc. | Methods and apparatus for securely displaying digital images |
US8151327B2 (en) | 2006-03-31 | 2012-04-03 | The 41St Parameter, Inc. | Systems and methods for detection of session tampering and fraud prevention |
US8779981B2 (en) * | 2009-02-27 | 2014-07-15 | The 41St Parameter, Inc. | 2D web trilateration |
US9112850B1 (en) | 2009-03-25 | 2015-08-18 | The 41St Parameter, Inc. | Systems and methods of sharing information through a tag-based consortium |
US8341236B1 (en) * | 2009-11-02 | 2012-12-25 | Ravi Ganesan | Privacy and security enhanced internet geolocation |
US10587683B1 (en) | 2012-11-05 | 2020-03-10 | Early Warning Services, Llc | Proximity in privacy and security enhanced internet geolocation |
US10581834B2 (en) | 2009-11-02 | 2020-03-03 | Early Warning Services, Llc | Enhancing transaction authentication with privacy and security enhanced internet geolocation and proximity |
US8806592B2 (en) | 2011-01-21 | 2014-08-12 | Authentify, Inc. | Method for secure user and transaction authentication and risk management |
CN103004102B (en) * | 2010-05-13 | 2015-12-09 | 西北大学 | Geo-positioning system and method |
JP2012009977A (en) * | 2010-06-23 | 2012-01-12 | Panasonic Corp | Network system |
WO2012054646A2 (en) | 2010-10-19 | 2012-04-26 | The 41St Parameter, Inc. | Variable risk engine |
US8776221B2 (en) * | 2011-05-11 | 2014-07-08 | Cisco Technology, Inc. | Distinguishing between voice traffic and data links |
US10754913B2 (en) | 2011-11-15 | 2020-08-25 | Tapad, Inc. | System and method for analyzing user device information |
US9633201B1 (en) | 2012-03-01 | 2017-04-25 | The 41St Parameter, Inc. | Methods and systems for fraud containment |
US9521551B2 (en) | 2012-03-22 | 2016-12-13 | The 41St Parameter, Inc. | Methods and systems for persistent cross-application mobile device identification |
WO2014022813A1 (en) | 2012-08-02 | 2014-02-06 | The 41St Parameter, Inc. | Systems and methods for accessing records via derivative locators |
WO2014078569A1 (en) | 2012-11-14 | 2014-05-22 | The 41St Parameter, Inc. | Systems and methods of global identification |
US9094331B2 (en) * | 2013-01-07 | 2015-07-28 | Verizon Patent And Licensing Inc. | Method and apparatus for internet protocol (IP) logical wire security |
US9541630B2 (en) * | 2013-02-15 | 2017-01-10 | Qualcomm Incorporated | Method and apparatus for determining a change in position of a location marker |
US20140341085A1 (en) * | 2013-05-14 | 2014-11-20 | Qualcomm Incorporated | Selecting an application server at which to register one or more user equipments for an internet protocol multimedia subsystem (ims) session |
US10902327B1 (en) | 2013-08-30 | 2021-01-26 | The 41St Parameter, Inc. | System and method for device identification and uniqueness |
ES2595487T3 (en) * | 2014-05-20 | 2016-12-30 | Proxistore S.A. | Geolocation method |
US10091312B1 (en) | 2014-10-14 | 2018-10-02 | The 41St Parameter, Inc. | Data structures for intelligently resolving deterministic and probabilistic device identifiers to device profiles and/or groups |
US9614845B2 (en) | 2015-04-15 | 2017-04-04 | Early Warning Services, Llc | Anonymous authentication and remote wireless token access |
US10084782B2 (en) | 2015-09-21 | 2018-09-25 | Early Warning Services, Llc | Authenticator centralization and protection |
CN107508925A (en) * | 2016-06-14 | 2017-12-22 | 阿里巴巴集团控股有限公司 | A kind of method and apparatus for being used to determine the regional information of IP address |
US10263849B2 (en) * | 2016-10-25 | 2019-04-16 | Servicenow, Inc. | System and method for generating discovery profiles for discovering components of computer networks |
US11164206B2 (en) * | 2018-11-16 | 2021-11-02 | Comenity Llc | Automatically aggregating, evaluating, and providing a contextually relevant offer |
US20210204116A1 (en) | 2019-12-31 | 2021-07-01 | Payfone, Inc. | Identity verification platform |
US12058528B2 (en) | 2020-12-31 | 2024-08-06 | Prove Identity, Inc. | Identity network representation of communications device subscriber in a digital domain |
US11601337B1 (en) | 2021-10-29 | 2023-03-07 | Kyndryl, Inc. | Virtual server geolocation detection |
US12058205B1 (en) * | 2023-08-01 | 2024-08-06 | Cisco Technology, Inc. | Opportunistic client locating for fast edge server association |
Family Cites Families (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6711137B1 (en) * | 1999-03-12 | 2004-03-23 | International Business Machines Corporation | System and method for analyzing and tuning a communications network |
US6587878B1 (en) * | 1999-05-12 | 2003-07-01 | International Business Machines Corporation | System, method, and program for measuring performance in a network system |
US20040143392A1 (en) * | 1999-07-12 | 2004-07-22 | Skybitz, Inc. | System and method for fast acquisition reporting using communication satellite range measurement |
US6762997B1 (en) * | 2000-03-29 | 2004-07-13 | Lucent Technologies Inc. | Method for finding shortest network routing paths subject to system constraints |
US6665715B1 (en) * | 2000-04-03 | 2003-12-16 | Infosplit Inc | Method and systems for locating geographical locations of online users |
US7065584B1 (en) * | 2000-04-28 | 2006-06-20 | Lucent Technologies Inc. | Method and apparatus for network mapping using end-to-end delay measurements |
US6681099B1 (en) * | 2000-05-15 | 2004-01-20 | Nokia Networks Oy | Method to calculate true round trip propagation delay and user equipment location in WCDMA/UTRAN |
US7111073B1 (en) * | 2000-05-30 | 2006-09-19 | Cisco Technology, Inc. | Apparatus for estimating delay and jitter between network routers |
JP3740953B2 (en) * | 2000-06-13 | 2006-02-01 | 株式会社日立製作所 | Wireless position measuring terminal and wireless position measuring system |
US7363367B2 (en) * | 2000-10-17 | 2008-04-22 | Avaya Technology Corp. | Systems and methods for robust, real-time measurement of network performance |
US7296088B1 (en) * | 2000-11-17 | 2007-11-13 | Microsoft Corporation | System and method for determining the geographic location of internet hosts |
US6937569B1 (en) * | 2001-05-21 | 2005-08-30 | Cisco Technology, Inc. | Method and system for determining a relative position of a device on a network |
JP2004242122A (en) * | 2003-02-07 | 2004-08-26 | Hitachi Ltd | Method and system for positioning terminal location based on propagation time difference of radio signal |
US7649838B2 (en) * | 2003-03-31 | 2010-01-19 | Adknowledge, Inc. | System and method for ranking the quality of internet traffic directed from one web site to another |
US20050071417A1 (en) * | 2003-09-29 | 2005-03-31 | Jeffrey Taylor | Method and apparatus for geolocation of a network user |
US7975035B2 (en) * | 2003-12-01 | 2011-07-05 | International Business Machines Corporation | Method and apparatus to support application and network awareness of collaborative applications using multi-attribute clustering |
US7827279B2 (en) * | 2004-01-30 | 2010-11-02 | Hewlett-Packard Development Company, L.P. | Selecting nodes close to another node in a network using location information for the nodes |
US7644167B2 (en) * | 2004-01-30 | 2010-01-05 | Hewlett-Packard Development Company, L.P. | Identifying a service node in a network |
JP4122328B2 (en) * | 2004-10-26 | 2008-07-23 | 富士通株式会社 | Transmission equipment |
US7466656B2 (en) * | 2004-10-26 | 2008-12-16 | International Business Machines Corporation | Method, apparatus and program storage device for efficient construction of network overlays through interconnection topology embedding |
US20060209717A1 (en) * | 2005-03-16 | 2006-09-21 | Puneet Sharma | Distributed storing of network position information for nodes |
US7948917B2 (en) * | 2005-10-27 | 2011-05-24 | Alcatel-Lucent Usa Inc. | Routing internet communications using network coordinates |
US20070182631A1 (en) * | 2006-02-09 | 2007-08-09 | Berlinsky Allan M | Internet based assisted global positioning system |
US8428098B2 (en) * | 2006-07-06 | 2013-04-23 | Qualcomm Incorporated | Geo-locating end-user devices on a communication network |
EP2047290A2 (en) * | 2006-08-01 | 2009-04-15 | Qualcomm Incorporated | System and/or method for providing information updates to a location server |
US7983691B1 (en) * | 2006-11-06 | 2011-07-19 | Google Inc. | Geographically localizing mobile communciation devices |
US8229457B2 (en) * | 2007-02-23 | 2012-07-24 | Ntt Docomo, Inc. | Positioning system, positioning method, and positioning program |
US8086249B1 (en) * | 2008-08-25 | 2011-12-27 | Clearwire IP Holdings, LLC | Ranging of wireless communication networks with distant wireless links |
-
2008
- 2008-12-16 US US12/336,163 patent/US8180887B2/en not_active Expired - Fee Related
-
2009
- 2009-11-20 WO PCT/US2009/065295 patent/WO2010074857A2/en active Application Filing
- 2009-11-20 EP EP09835455.8A patent/EP2359533B1/en active Active
- 2009-11-20 CN CN200980151579.9A patent/CN102246463B/en active Active
Non-Patent Citations (1)
Title |
---|
None * |
Also Published As
Publication number | Publication date |
---|---|
CN102246463A (en) | 2011-11-16 |
WO2010074857A3 (en) | 2010-08-19 |
EP2359533A4 (en) | 2017-01-25 |
CN102246463B (en) | 2014-11-26 |
WO2010074857A2 (en) | 2010-07-01 |
US20100153540A1 (en) | 2010-06-17 |
EP2359533A2 (en) | 2011-08-24 |
US8180887B2 (en) | 2012-05-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP2359533B1 (en) | Geolocation mapping of network devices | |
US7711846B2 (en) | System and method for determining the geographic location of internet hosts | |
CN108027800B (en) | Method, system and apparatus for geolocation using traceroute | |
Katz-Bassett et al. | Towards IP geolocation using delay and topology measurements | |
KR101154799B1 (en) | Dns wildcard beaconing to determine client location and resolver load for global traffic load balancing | |
EP2936189B1 (en) | Determining a location of a mobile user terminal | |
US7471954B2 (en) | Methods and systems for estimating a user position in a WLAN positioning system based on user assigned access point locations | |
Balakrishnan et al. | Where's that phone? Geolocating IP addresses on 3G networks | |
KR101249178B1 (en) | Continuous data optimization in positioning system | |
EP1992179B1 (en) | Methods and systems for estimating a user position in a wlan positioning system based on user assigned access point locations | |
CN101336556B (en) | Method and arrangement for high precision position reference measurements at indoor locations | |
Du et al. | RIPE IPmap active geolocation: Mechanism and performance evaluation | |
JP2009543075A (en) | Geographic location of end-user devices on a communications network | |
Youn et al. | Statistical geolocation of internet hosts | |
Dan et al. | Ip geolocation using traceroute location propagation and ip range location interpolation | |
EP2469292B1 (en) | Location estimation by observing wireless signals | |
Ciavarrini et al. | Smartphone-based geolocation of Internet hosts | |
US20080137554A1 (en) | Method Of Geographicallly Locating Network Addresses Incorporating Probabilities, Inference And Sets | |
Hillmann et al. | Dragoon: advanced modelling of IP geolocation by use of latency measurements | |
CA2628121A1 (en) | Methods and systems for wireless network survey, location and management | |
Hillmann et al. | Modelling of IP Geolocation by use of Latency Measurements | |
KR101686536B1 (en) | System and method for managing call quality information using access point | |
US9203710B2 (en) | Location of equipment by its IP address | |
Prieditis et al. | Mapping the internet: geolocating routers by using machine learning | |
Gharaibeh | Characterizing the Visible Address Space to Enable Efficient Continuous IP Geolocation |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
17P | Request for examination filed |
Effective date: 20110610 |
|
AK | Designated contracting states |
Kind code of ref document: A2 Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO SE SI SK SM TR |
|
DAX | Request for extension of the european patent (deleted) | ||
RAP1 | Party data changed (applicant data changed or rights of an application transferred) |
Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC |
|
A4 | Supplementary search report drawn up and despatched |
Effective date: 20170103 |
|
RIC1 | Information provided on ipc code assigned before grant |
Ipc: H04L 29/02 20060101ALI20161221BHEP Ipc: H04L 12/24 20060101AFI20161221BHEP |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R079 Ref document number: 602009056445 Country of ref document: DE Free format text: PREVIOUS MAIN CLASS: H04L0012240000 Ipc: H04L0029080000 |
|
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: GRANT OF PATENT IS INTENDED |
|
RIC1 | Information provided on ipc code assigned before grant |
Ipc: H04W 4/02 20090101ALI20180522BHEP Ipc: H04L 29/08 20060101AFI20180522BHEP |
|
INTG | Intention to grant announced |
Effective date: 20180612 |
|
GRAS | Grant fee paid |
Free format text: ORIGINAL CODE: EPIDOSNIGR3 |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE PATENT HAS BEEN GRANTED |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO SE SI SK SM TR |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: EP |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: REF Ref document number: 1082988 Country of ref document: AT Kind code of ref document: T Effective date: 20190115 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R096 Ref document number: 602009056445 Country of ref document: DE |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: FP |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LV Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: HR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: BG Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20190326 Ref country code: NO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20190326 Ref country code: LT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
REG | Reference to a national code |
Ref country code: LT Ref legal event code: MG4D |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20190327 |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: MK05 Ref document number: 1082988 Country of ref document: AT Kind code of ref document: T Effective date: 20181226 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20190426 Ref country code: CZ Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: PL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: RO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: SK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20190426 Ref country code: SM Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: EE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R097 Ref document number: 602009056445 Country of ref document: DE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
26N | No opposition filed |
Effective date: 20190927 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: TR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MC Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: CH Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20191130 Ref country code: LI Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20191130 Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20191120 |
|
REG | Reference to a national code |
Ref country code: BE Ref legal event code: MM Effective date: 20191130 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20191120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20191130 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 Ref country code: HU Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO Effective date: 20091120 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R079 Ref document number: 602009056445 Country of ref document: DE Free format text: PREVIOUS MAIN CLASS: H04L0029080000 Ipc: H04L0065000000 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20181226 |
|
P01 | Opt-out of the competence of the unified patent court (upc) registered |
Effective date: 20230505 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: NL Payment date: 20231020 Year of fee payment: 15 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20231019 Year of fee payment: 15 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 20231020 Year of fee payment: 15 Ref country code: DE Payment date: 20231019 Year of fee payment: 15 |