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

时间:2014-08-18 23:01:35

标签: hive geoip maxmind

我有一个自定义配置单元UDF来访问通过“添加文件pqr.mmdb”添加到配置单元资源的Maxmind的 GeoIP-country.mmdb 数据库。编译的UDF添加为“add jar abc.jar” 当我运行一个配置单元查询时,java类尝试访问geo数据库中的数据并通过抛出以下异常而失败。

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();

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

1 个答案:

答案 0 :(得分:2)

(将其移至实际答案。)

geoip2-0.8.0-with-dependencies.zip file包含API所依赖的所有JAR。 ZIP文件是在构建GeoIP2期间创建的。包含的JAR是pom.xml file中列出的依赖项的依赖项或依赖项。该邮政编号列在releases page