Skip to content

beermeat/geoip-rs

 
 

Repository files navigation

geoip-rs

Latest version Build Status

geoip-rs is a geoip service: it provides geographical information about the calling or the specified IP address. It supports both IPV4 and IPV6.

Example response

Valid ip address:

{
  "ip_address": "46.51.179.90",
  "latitude": 53.3331,
  "longitude": -6.2489,
  "postal_code": "D02",
  "continent_code": "EU",
  "continent_name": "Europe",
  "country_code": "IE",
  "country_name": "Ireland",
  "region_code": "L",
  "region_name": "Leinster",
  "province_code": "",
  "province_name": "",
  "city_name": "Dublin",
  "timezone": "Europe/Dublin"
}

Not found (private) ip address:

{
  "ip_address": "127.0.0.1"
}

Speed

On an 8 cores Intel i7, geoip.rs can serve ~30K requests/sec.

Dataset

geoip-rs uses the free dataset provided by maxmind. It's not bundled: you have to download it separately.

Download "GeoLite2 City" dataset in binary format from here and unzip it.

Running

Install geoip.rs with

cargo install geoip-rs

If you don't have cargo, install it with

curl https://sh.rustup.rs -sSf | sh

or read the tutorial for additional instructions.

You can specify the dataset location on the command line

geoip-rs /path/to/GeoLite2-City.mmdb

or via environment variable

export GEOIP_RS_DB_PATH=/path/to/GeoLite2-City.mmdb
geoip-rs

or via .env

cp .env.template .env
#edit .env appropriately
geoip-rs

You can also customize the host and port geoip.rs will listen to

export GEOIP_RS_DB_PATH=/path/to/GeoLite2-City.mmdb
export GEOIP_RS_HOST=192.168.0.1
export GEOIP_RS_PORT=8080
geoip-rs

or you can copy .env.template to .env and customize its contents

Running in docker

Many thanks to P3TERX/GeoLite.mmdb for distributing the database. Check releases here and set the last value in the GEOLIGHT_RELEASE environment variable when building the image.

Up your own image:

ln -s docker/docker-compose.dev.yml docker-compose.yml
cp docker/.env.dist .env
docker compose up -d
curl http://127.0.0.1:8080/?ip=46.51.179.90

Push your own image to hub.docker.com:

docker compose build geoip-rs
docker tag geoip-rs-geoip-rs:latest {REPO}/geoip-rs:{VERSION}
docker tag geoip-rs-geoip-rs:latest {REPO}/geoip-rs:latest
docker push {REPO}/geoip-rs:{VERSION}
docker push {REPO}/geoip-rs:latest

Or just use the existing:

docker run -p 8080:8080 beermeat/geoip-rs:latest

License

This project is licensed under the Apache License, Version 2.0

About

geoip service written in rust https://geoip.rs/

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 88.4%
  • Dockerfile 11.6%