我有一个自定义的hive UDF来访问Maxmind的GeoIP-country。通过"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文件都被添加到hive资源中。
reader = new DatabaseReader.Builder(database).fileMode(Reader.FileMode.MEMORY_MAPPED).build();
和
reader = new DatabaseReader.Builder(database).fileMode(Reader.FileMode.MEMORY).build();
有人遇到过类似的问题吗?谢谢!——Lalith
(将此移为实际答案)
geoip2-0.8.0-with-dependencies.zip文件包含API所依赖的所有jar。ZIP文件是在构建GeoIP2期间创建的。包含的jar是pom.xml文件中列出的所有依赖项或依赖项的依赖项。zip在发布页面中列出。