This is a pre-configured, ready-to-run MongoDB server with IP2Location Geolocation database setup scripts. It simplifies the development team to install and set up the IP2Location geolocation database in MongoDB server. The setup script supports the commercial database packages and free LITE package. Please register for a free or commercial account before running this image, as it requires a download token during the setup process.
This docker image supports the IP2Location (DB1 to DB26) database.
-
Create a dedicated network so that your application containers can communicate with the IP2Location container by name.
docker network create ip2location-network
-
Run this image as daemon using the download token and product code from IP2Location LITE or IP2Location and attaching it to the network created above.
docker run --name ip2location \ --network ip2location-network \ -d \ -e TOKEN={DOWNLOAD_TOKEN} \ -e CODE={DOWNLOAD_CODE} \ -e MONGODB_PASSWORD={MONGODB_PASSWORD} \ ip2location/mongodbENV Variables
TOKEN- Download token obtained from IP2Location.CODE- The CSV file download code. You may get the download code from your account panel.MONGODB_PASSWORD- Password for MongoDB admin. -
The installation may take seconds to minutes depending on your database sizes, downloading speed and hardware specs. You may check the installation status by viewing the container logs. Run the below command to check the container log:
docker logs -f ip2locationYou should see the line
> Setup completedif you have successfully completed the installation.
Run your application container on the same network. The IP2Location container is reachable by its container name (ip2location) as the hostname:
docker run --network ip2location-network -t -i {YOUR_APPLICATION}-
In your application container, install MongoDB and Mongo Shell first by following the installation steps in https://docs.mongodb.com/manual/tutorial/install-mongodb-on-debian/.
-
Run the Mongo Shell with the password you've specified during the installation and connect to
ip2locationhost.mongosh --host ip2location -u mongoAdmin -p {MONGODB_PASSWORD} --authenticationDatabase admin -
To test the IPv4 database, key in the commands below to query geolocation info for IPv4 address
8.8.8.8(IP number: 134744072).use ip2location_database db.ip2location_database.findOne( { ip_to: { $gte: 134744072 } } ) -
To test the IPv6 database, key in the commands below to query geolocation info for IPv6 address
2001:4860:4860::8888(IP number: 42541956123769884636017138956568135816).use ip2location_database db.ip2location_database.findOne( { ip_to_index: { $gte: "A0042541956123769884636017138956568135816" } } )If you don't know how to convert an IP address to IP number, please see IP2Location FAQs.
NOTES: The search param for IPv4 database is a number BUT the param for IPv6 database is a string of the IP number left-padded with zeroes till 40 characters and prefixed with an "A".
Also, IPv6 database is filtering on the
ip_to_indexfield while IPv4 database is filtering on theip_tofield. When querying IPv4 address using the IPv6 database, you need to convert the IPv4 address into IPv4-mapped IPv6 address before converting to IP number.
To update your IP2Location database to latest version, please run the following command:
docker exec -it ip2location ./update.shYou can visit the below link for more information about this docker image: IP2Location Articles and Tutorials