GeoIP2 Enterprise Databases

Determine geolocation data such as country, region, state, city, ZIP/postal code, and additional intelligence such as confidence factors, ISP, domain, and connection type.

To learn more about the GeoIP2 Enterprise database, please visit the GeoIP2 Enterprise Database page.

If you are interested in purchasing the database, please contact our Enterprise Business team for assistance.

IP Geolocation Usage

IP geolocation is inherently imprecise. Locations are often near the center of the population. Any location provided by a GeoIP database should not be used to identify a particular address or household.

Data Privacy

To comply with data privacy regulations, please monitor our Do Not Sell My Personal Information Requests page (login required) for IP addresses and networks that should not be used for advertising or marketing purposes. You can automate retrieval of this list using our privacy exclusions API.

Binary Database

Binary databases make use of the MaxMind DB file format. MaxMind provides official client APIs in the language listed below. The following client APIs are open source and licensed under the Apache License, Version 2.0.

You can also use the mmdbinspect tool (in beta), a command line interface built with Go, to look up one or more IPs from one or more MMDB databases and receive output in a parsable JSON format.

CSV Database

In addition to our MaxMind DB binary format, we also offer GeoIP2 and GeoLite2 databases in a CSV format suitable for importing into a SQL database. The CSV files are shipped as a single zip file.

The zip file itself is named GeoIP2-Enterprise-CSV_{YYYYMMDD}.zip. The downloaded zip file contains a single directory which in turn contains several files. That directory is named GeoIP2-Enterprise-CSV_{YYYYMMDD}.

The files in thie zip archive are:

FilenameDescription
COPYRIGHT.txtCopyright statement
LICENSE.txtEnd user license
GeoIP2-Enterprise-Blocks-IPv4.CSVCSV file containing data on IPv4 addresses
GeoIP2-Enterprise-Blocks-IPv6.CSVCSV file containing data on IPv6 addresses
GeoIP2-Enterprise-ISP.CSVCSV file containing data on ISPs. This may be cross referenced with the various blocks files using the shared `isp_id` key.
GeoIP2-Enterprise-Locations-XX.CSVCSV files containing data on locations. This may be cross referenced with the various blocks files using the shared `geoname_id` key.
All the CSV files start with a single header row containing column names. The specific column names and their contents are detailed below. The files are encoded as UTF-8.

Blocks Files

There are two CSV files for network blocks, one each for IPv4 and IPv6 blocks. These files are named GeoIP2-Enterprise-Blocks-IPv4.csv and GeoIP2-Enterprise-Blocks-IPv6.csv respectively.

NameTypeDescription
networkIP network as a stringThis is the IPv4 or IPv6 network in CIDR format such as "2.21.92.0/29" or "2001:4b0::/80". We offer a utility to convert this column to start/end IPs or start/end integers. See the conversion utility section for details.
geoname_idintegerA unique identifier for the network's location as specified by GeoNames . This ID can be used to look up the location information in the Location file.

Learn more about GeoNames IDs on our Knowledge Base.
registered_country_geoname_idintegerThe registered country is the country in which the ISP has registered the network. This column contains a unique identifier for the network's registered country as specified by GeoNames . This ID can be used to look up the location information in the Location file.

Learn more about registered countries on our Knowledge Base.
represented_country_geoname_idintegerThe represented country is the country which is represented by users of the IP address. For instance, the country represented by an overseas military base. This column contains a unique identifier for the network's represented country as specified by GeoNames . This ID can be used to look up the location information in the Location file.

Learn more about represented countries on our Knowledge Base.
is_anonymous_proxybooleanDeprecated. Please see our GeoIP2 Anonymous IP database to determine whether the IP address is used by an anonymizing service.
is_satellite_providerbooleanDeprecated.
postal_codestringA postal code close to the user's location. For the following countries, we return partial postal codes with the number of characters indicated below:
  • United States: 5
  • Canada: 3
  • United Kingdom: 2-4
  • Brazil: 5
  • Ireland: 3
  • Japan: 7 (specified for the first 6. The last digit defaults to 1)
  • Netherlands: 4
  • Portugal: 7 (accurate for the first 4. The last 3 often defaults to -001 )
  • Singapore: 2
latitude*decimalThe approximate WGS84 latitude of the location associated with the network.

Learn about the geolocation area defined by latitude, longitude, and accuracy radius, on our Knowledge Base.
longitude*decimalThe approximate WGS84 longitude of the location associated with the network.

Learn about the geolocation area defined by latitude, longitude, and accuracy radius, on our Knowledge Base.
accuracy_radiusintegerThe radius in kilometers around the specified location where the IP address is likely to be.

Learn about the geolocation area defined by latitude, longitude, and accuracy radius, on our Knowledge Base.
isp_idintegerA identifier for the ISP. This ID can be used to look up the location information in the ISP file.

Learn more about ISP data on our Knowledge Base.
domainstringThe domain associated with the network.

Learn more about domain name data on our Knowledge Base.
country_confidencedecimal (1-100)The confidence that the country was correctly geolocated.

Learn more about confidence factors on our Knowledge Base.
subdivision_confidencedecimal (1-100)The confidence that the most specific subdivision was correctly geolocated.

Learn more about confidence factors on our Knowledge Base.
city_confidencedecimal (1-100)The confidence that the city was correctly geolocated.

Learn more about confidence factors on our Knowledge Base.
postal_confidencedecimal (1-100)The confidence that the postal code was correctly geolocated.

Learn more about confidence factors on our Knowledge Base.
is_legitimate_proxybooleanDeprecated. Use the user_type data to identify traffic from businesses. Learn more about user_type data on our knowledge base . To identify anonymous proxies, you can learn more about the GeoIP2 Anonymous IP database in the developer portal or our main website .
is_anycastbooleanThis is 1 if the network is an anycast network .
* The coordinates are not precise and should not be used to identify a particular street address or household. To better represent a level of accuracy, please include the accuracy_radius when displaying latitude and longitude and make it clear that the coordinates refer to a larger geographical area instead of a precise location.

ISP File

A single CSV file, called GeoIP2-Enterprise-ISP.csv, contains information on ISPs.

NameTypeDescription
isp_idintegerThe identifier for the ISP. This key can be cross referenced with the `isp_id` in the Blocks files.
ispstringThe name of the ISP associated with the IP address.
organizationstringThe name of the organization associated with the IP address.
autonomous_system_numberintegerThe ASN assigned to the ISP for routing.
autonomous_system_organizationstringThe name of the autonomous system organization.
connection_typestringThe type of connection. This will be one of the following values:
  • Cable/DSL
  • Cellular
  • Corporate
  • Satellite
user_typestringThe user type associated with the IP address. This will be one of the following values.
  • business
  • cafe
  • cellular
  • college
  • consumer_privacy_network
  • content_delivery_network
  • government
  • hosting
  • library
  • military
  • residential
  • router
  • school
  • search_engine_spider
  • traveler
mobile_country_codestringThe mobile country code (MCC) associated with the IP address and ISP.
mobile_network_codestringThe mobile network code (MNC) associated with the IP address and ISP.

Locations Files

The zip file includes one location file for each locale code for which data is available. There will always be an “en” file containing a record for every geoname_id used in the blocks files. Files corresponding to other locales will exist and have a record for a geoname_id only if data is available. The other possible locales are “de”, “es”, “fr”, “ja”, “pt-BR”, “ru”, and “zh-CN”.

These files are named GeoIP2-Enterprise-Locations-{locale}.csv. An example name would be “GeoIP2-City-Locations-en.csv”.

NameTypeDescription
geoname_idintegerA unique identifier for the a location as specified by GeoNames . This ID can be used as a key for the Location file.

Learn more about GeoNames IDs on our Knowledge Base.
locale_codestringThe locale that the names in this row are in. This will always correspond to the locale name of the file.
continent_codestring (2)

The continent code for this location. Possible codes are:

  • AF - Africa
  • AN - Antarctica
  • AS - Asia
  • EU - Europe
  • NA - North America
  • OC - Oceania
  • SA - South America
continent_namestringThe continent name for this location in the file's locale.

Learn more about localized names on our Knowledge Base.
country_iso_codestring (2)A two-character ISO 3166-1 country code for the country associated with the location.
country_namestringThe country name for this location in the file's locale.

Learn more about localized names on our Knowledge Base.
subdivision_1_iso_codestring (1-3)A string of up to three characters containing the region-portion of the ISO 3166-2 code for the first level region associated with the IP address. Some countries have two levels of subdivisions, in which case this is the least specific. For example, in the United Kingdom this will be a country like "England", not a county like "Devon".
subdivision_1_namestringThe subdivision name for this location in the file's locale. As with the subdivision code, this is the least specific subdivision for the location.

Learn more about localized names on our Knowledge Base.
subdivision_2_iso_codestring (1-3)A string of up to three characters containing the region-portion of the ISO 3166-2 code for the second level region associated with the IP address. Some countries have two levels of subdivisions, in which case this is the most specific. For example, in the United Kingdom this will be a a county like "Devon", not a country like "England".
subdivision_2_namestringThe subdivision name for this location in the file's locale. As with the subdivision code, this is the most specific subdivision for the location.

Learn more about localized names on our Knowledge Base.
city_namestringThe city name for this location in the file's locale.

Learn more about localized names on our Knowledge Base.
metro_codeintegerMetro code is a geolocation target code from Google.
time_zonestringThe time zone associated with location, as specified by the IANA Time Zone Database , e.g., “America/New_York”.
is_in_european_unionbooleanThis is 1 if the country associated with the location is a member state of the European Union. It is 0 otherwise.

Returned Values as Database, Map, Dict, or Hash Keys

We strongly discourage you from using a value from any *_name field as a key in a database or map/dict/hash data structure.

These names may change between releases. Instead we recommend using one of the following:

Data objectRecommended key
citygeoname_id
continentcontinent_code
countrycountry_iso_code
postalpostal_code
subdivisionssubdivision_{1,2}_iso_code

Conversion Utility

We’ve created a small utility program to allow you to convert a GeoIP2 CSV file’s representation of IP addresses to another format. You can choose between start/end IP addresses, with the addresses represented as strings or integers.

The program is available from our geoip2-csv-converter GitHub project releases tab.

Example Files

We maintain example files in CSV and MMDB format. The files contain dummy data rather than real GeoIP data.

CSV Example Files

We maintain examples of the CSV files as they would be downloaded from the account portal:

MMDB Example Files

We maintain test MMDB files on GitHub:

Alternatively, you can view all of our MMDB test data on GitHub.

Database Changes

We may add new data fields to the Enterprise database at any time.

New database fields are added as new columns to the right of existing columns in our CSV files, and as additional data in our MMDB files.

Subscribe to our GeoIP2 release notes to be notified when new data is added to our databases.

Database Sizes

MaxMind databases can vary in size from release to release. If you are working with file size limitations that are concerning, you should build your integrations to fail gracefully in event of a significant size change.

From August to October 2024, the database files varied in file size and number of networks as follows:

DatabaseCSV File SizeMMDB File SizeIPv4 NetworksIPv6 Networks
GeoIP Enterprise986 MB - 1.05 GB344 MB - 358 MB7,874,000 - 8,984,0003,251,000 - 3,772,000

The listed file sizes are for unpacked databases. Databases are downloaded in a compressed format.

APIs and Third-Party Integrations

You can find a complete list of official and unofficial client APIs,and third-party integrations on the database documentation page.