Java IP地址解析工具ip2region

ip2region

一、介绍

在移动互联网的应用中,经常需要根据用户的位置信息等做一些用户侧信息的统计分析。而要拿到用户的位置信息,一般有两个方法: GPS 定位的信息和用户 IP 地址。由于每个手机都不一定会打开 GPS,而且有时并不太需要太精确的位置(到城市这个级别即可),所以根据 IP 地址入手来分析用户位置是个不错的选择。 要做到这个功能得需要一个 IP 和地理位置的映射关系库,并依赖这个库启动一个 IP 转地理位置的服务。而 ip2region 来分析映射关系库的设计以及 IP 如何快速转换成地理位置。

二、使用上手

1、引入库
<!-- ip2region -->
<dependency>
    <groupId>org.lionsoul</groupId>
    <artifactId>ip2region</artifactId>
    <version>1.7.2</version>
</dependency>

码云的地址:https://gitee.com/lionsoul/ip2region

2、下载ip2region.db文件

下载地址:https://gitee.com/lionsoul/ip2region/blob/master/data/ip2region.db

首先从以上地址下载ip2region.db文件。下载文件后将下载的文件添加到项目的resoure路径下

在这里插入图片描述

3、使用上手
   /**
     * 根据IP地址获取城市
     *
     * @param ip
     * @return
     */
    public static String getCityInfo(String ip) throws Exception {
        //读取jar包内的配置文件信息
        DbSearcher searcher = null;
        Method method = null;
        InputStream inputStream = null;
        try {
            ClassPathResource resource = new ClassPathResource("/ip2region.db");
            inputStream = resource.getInputStream();
            byte[] dbBinStr = IoUtil.readBytes(inputStream);
            DbConfig config = new DbConfig();
            searcher = new DbSearcher(config, dbBinStr);
            // 查询算法memory,采用二进制方式初始化DBSearcher需要使用MEMORY_ALGORITYM,
            //否则会抛出null。
            method = searcher.getClass().getMethod("memorySearch", String.class);
        } catch (IOException | DbMakerConfigException | IORuntimeException | NoSuchMethodException | SecurityException e) {
            log.error(e.getMessage());
            e.printStackTrace();
        } finally {
            if (inputStream != null) {
                inputStream.close();
            }
        }
        return ((DataBlock) method.invoke(searcher, ip)).getRegion();
    }

在查询IP时有三种算法,分别是:

  1. memory算法:整个数据库全部载入内存,单次查询都在0.1x毫秒内,C语言的客户端单次查询在0.00x毫秒级别。
method = searcher.getClass().getMethod("memorySearch", String.class);
  1. binary算法:基于二分查找,基于ip2region.db文件,不需要载入内存,单次查询在0.x毫秒级别。
method = searcher.getClass().getMethod("binarySearch", String.class);
  1. b-tree算法:基于btree算法,基于ip2region.db文件,不需要载入内存,单词查询在0.x毫秒级别,比binary算法更快。
method = searcher.getClass().getMethod("btreeSearch", String.class);
4、注意事项

ip2region 并发使用

  • 全部binding的各个search接口都不是线程安全的实现,不同线程可以通过创建不同的查询对象来使用,并发量很大的情况下,binary和b-tree算法可能会打开文件数过多的错误,请修改内核的最大允许打开文件数(fs.file-max=一个更高的值),或者使用持久化的memory算法。

  • memorySearch接口,在发布对象前进行一次预查询(本质上是把ip2region.db文件加载到内存),可以安全用于多线程环境。

注:ip2region 并发使用内容摘自于码云,如果想了解更多可以自行搜索

5、输出内容含义

输出内容实例:|中国|华南|广东省|广州市|电信

分别代表国家、区域、省份、市和运营商。无数据区域默认为0。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fly狮子座

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值