Импортер ipgeo-данных в файлы, понятные для nginx geo module, с поддержкой кодов регионов РФ.
Поддерживает Ipgeobase.ru, TOR-списки, MaxMind GeoLite (для городов), Lite.ip2location базы ip2proxy.
- Скачать соответствующий архитектуре бинарник с github куда-нибудь в $PATH
- Сделать его исполняемым
- Пользоваться
(также, при наличии Go окружения можно собрать самостоятельно через go get + go build)
По умолчанию, ip2geo генерирует все возможные map-файлы, но все настраиваемо с помощью ключей:
-output string
Директория для записи map-файлов (по умолчанию: "output")
-q Be quiet - skip [OK]
-qq Be very quiet - show only errors
-ipgeobase
Генерация IPgeobase баз (название города, код региона, часовой пояс)
-tor
Генерация списков TOR нод.
-ip2proxy
Генерация ip2proxy сетей
-ip2proxy-token string
Токен для скачивания ip2proxy баз https://lite.ip2location.com/file-download
-maxmind
Генерация баз MaxMind (название города, часовой пояс)
Дальше параметры для MaxMind:
-lang string
Язык MaxMind баз (по умолчанию ru)
-ipver int
MaxMind версия IP (4 or 6) (default 4)
-include string
MaxMind фильтр: использовать только перечисленные страны
Принимает список ISO-кодов стран, разделенных пробелами ("RU FR EN")
-exclude string
MaxMind фильтр: исключает из вывода перечисленные страны. (см формат выше)
geomap-файлы предназначены для использования в nginx в виде:
# Region
geo $region {
ranges;
include geo/region.txt;
}
# City
geo $city_geo {
ranges;
include geo/city.txt;
}
geo $city_mm {
ranges;
include geo/mm_city.txt;
}
map $city_geo $city {
"" $city_mm;
default $city_geo;
}
# TZ
geo $tz_geo {
ranges;
include geo/tz.txt;
}
geo $tz_mm {
ranges;
include geo/mm_tz.txt;
}
map $tz_geo $tz {
"" $tz_mm;
default $tz_geo;
}
# Tor
geo $is_tor {
ranges;
default 0;
include geo/tor.txt;
}
# Proxy
geo $is_proxy {
ranges;
default 0;
include geo/ip2proxy_net.txt;
}
Таким образом, IP адреса в файлах записаны в виде диапазона (range) и отсортированы по возрастанию IP. Карты сделаны каскадно, чтобы решить проблему пересечений диапазонов. IPGeobase используется в первую очередь, и если адрес там не найден, то MaxMind.
Для того, чтобы название города всегда отдавалось корректно - оно кодируется в base64 от utf8.