通过 hive 访问 maxmind 的 GeoIP-country.mmdb 数据库时出现异常

2024-05-08

我有一个自定义 Hive UDF 来访问 MaxmindGeoIP-国家.mmdb通过“add file pqr.mmdb”添加到 Hive 资源的数据库。编译好的 UDF 添加为“add jar abc.jar” 当我运行 hive 查询时,java 类在幕后尝试访问地理数据库中的数据,但因抛出以下异常而失败。

Error: java.lang.ClassNotFoundException: com.maxmind.db.Reader$FileMode
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
at com.maxmind.geoip2.DatabaseReader$Builder.<init>(DatabaseReader.java:68)

我分别尝试了以下两行,但仍然抛出相同的错误。我的数据库文件和 jar 都添加到配置单元资源中。

reader = new DatabaseReader.Builder(database).fileMode(Reader.FileMode.MEMORY_MAPPED).build();

AND

reader = new DatabaseReader.Builder(database).fileMode(Reader.FileMode.MEMORY).build();

有没有人遇到过类似的问题? 谢谢 ! - 拉莉丝


(将其移至实际答案。)

The geoip2-0.8.0-with-dependency.zip 文件 https://github.com/maxmind/GeoIP2-java/releases/download/v0.8.0/geoip2-0.8.0-with-dependencies.zip包含 API 依赖的所有 JAR。 ZIP 文件是在构建 GeoIP2 期间创建的。包含的 JAR 是所有依赖项或依赖项中列出的依赖项的依赖项pom.xml 文件 https://github.com/maxmind/GeoIP2-java/blob/master/pom.xml。邮编列于发布页面 https://github.com/maxmind/GeoIP2-java/releases.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

通过 hive 访问 maxmind 的 GeoIP-country.mmdb 数据库时出现异常 的相关文章

随机推荐