我有一个自定义配置单元 UDF 来访问 Maxmind 的GeoIP-country.mmdb数据库,该数据库通过“添加文件 pqr.mmdb”添加到配置单元资源中。编译后的 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();
和
reader = new DatabaseReader.Builder(database).fileMode(Reader.FileMode.MEMORY).build();
有没有人遇到过类似的问题?谢谢 !- 拉利斯