169 похожих чатов

Here is what you need to do: 1 - download the

geo-lite database
2- load it all into memory
3- make a b tree out of all the ranges available.


4- now you have an ip in your own database that want to know which country it belongs to right? So, lookup that IP in the b tree you create. Whichever range it matched on. Lookup the country for that range.

Now you know which country a given IP belongs to.

You can do whatever you want with that information in your original database

11 ответов

9 просмотров

Looks good I want t know which countries have most IPs in my database

Пользователь-61930 Автор вопроса
Kazem
Looks good I want t know which countries have most...

Same thing. Only you need some sort of map. You will lookup each ip in the b tree Then creat a map like {"Iran": 1} If you find another user form iran do Users["iran"] +1

Пользователь-61930 Автор вопроса
Kazem
Looks good I want t know which countries have most...

What language are you using for your project? geoip-lite might be available for your language.

Пользователь 61930
Same thing. Only you need some sort of map. You ...

Takes tooo long 😐 if user needs to use online mode takes more time

Пользователь-61930 Автор вопроса
Kazem
Takes tooo long 😐 if user needs to use online mode...

No it doesn't you're doing something that it just happens that I have done before. If you load geoip-lite into memory it takes up to 15sec but it's a one time cost. Then lookups are really fast in b tree. Like I'm talking 9ms response.

Пользователь-61930 Автор вопроса
Kazem
I use that feature in index page :D

What are you exactly trying to do?

Пользователь 61930
What are you exactly trying to do?

I've a table in my db that contains some IP addresses I'm wanting to show top 6 countries to users

Пользователь-61930 Автор вопроса
Kazem
screenshot for this section

I see, and you want to update this in real time?

Похожие вопросы

Обсуждают сегодня

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
а не подскажете вот это скрин из какой IDE ?
Iluha Companets
14
Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
48
Продолжая диалог про свифт в проде – сейчас возник вопрос в активном наборе бекендеров. В основном в нашей компании мы фанаты Java Spring и полностью ей довольны. Однако найм ...
Guseyn
27
Народ всем привет Подскажите, как включить самописные dll библиотеки в итоговую сборку Сейчас при запуске dev сервера локально формируется папка build, из которой запускается...
Андрей
4
Комрады, подскажите, в дельфях есть компоненты а-ля TDirectorySelect?
Ed Doc
15
Карта сайта