Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/305.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
通过java程序连接到配置单元数据库时出错_Java_Database_Hadoop_Hive - Fatal编程技术网

通过java程序连接到配置单元数据库时出错

通过java程序连接到配置单元数据库时出错,java,database,hadoop,hive,Java,Database,Hadoop,Hive,我想使用java程序连接到服务器上的配置单元数据库。下面是java的代码: import java.sql.SQLException; import java.sql.Connection; import java.sql.ResultSet; import java.sql.Statement; import java.sql.DriverManager; public class HiveQueryJava { private static String driverName =

我想使用java程序连接到服务器上的配置单元数据库。下面是java的代码:

import java.sql.SQLException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.DriverManager;


public class HiveQueryJava {

   private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";

   public static void main(String[] args) throws SQLException {

      // Register driver and create driver instance
      Class.forName(driverName);


      // get connection
      Connection con = DriverManager.getConnection("jdbc:hive -hiveconf mapred.job.queue.name=queuename://ip:port/dbname", "uname", "");

      // create statement
      Statement stmt = con.createStatement();

      // execute statement
      Resultset res = stmt.executeQuery("SELECT pincode FROM pincode_city_map LIMIT 5;");

      System.out.println("Result:");

      while (res.next()) {
         System.out.println(res.getString(1));
      }
      con.close();
   }
}
我为4个NoClassFoundException添加了3个jar文件。jar文件包括:

hive-service-0.11.0.jar
libthrift-0.8.0.jar
hive-jdbc-0.10.0.jar
hive-metastore-0.10.0
现在获取新的NoClassFoundException,如下所示:

Exception in thread "main" java.lang.NoClassDefFoundError: com/facebook/fb303/FacebookService$Iface
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(ClassLoader.java:760)
        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
        at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
        at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(ClassLoader.java:760)
        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
        at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
        at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(ClassLoader.java:760)
        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
        at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
        at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
        at org.apache.hadoop.hive.jdbc.HiveDriver.connect(HiveDriver.java:104)
        at java.sql.DriverManager.getConnection(DriverManager.java:664)
        at java.sql.DriverManager.getConnection(DriverManager.java:247)
        at HiveQueryJava.main(HiveQueryJava.java:21)
Caused by: java.lang.ClassNotFoundException: com.facebook.fb303.FacebookService$Iface
        at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
        ... 40 more
每次出现这个异常时,我都必须搜索这个类并下载一个jar文件。是否有任何主jar文件包含用于连接到配置单元数据库的所有jar


最后,我想通过java程序连接到hive。有人可以提供其他代码或建议解决此问题的其他方法吗?

类路径中缺少libfb*-*.jar。请确保类路径中包含的必要JAR版本正确且无任何重复

以下几页可能会有所帮助


类路径中缺少libfb*-*.jar。请确保类路径中包含的必要JAR版本正确且无任何重复

以下几页可能会有所帮助


如果您使用的是hortonworks,他们已经捆绑了所有的罐子。您可以使用以下两个罐子进行连接:-

此外,您只能连接配置单元服务器2,因此您的连接字符串应该与下面的字符串类似,请使用配置单元2而不是配置单元

 Connection con = DriverManager.getConnection("jdbc:hive2://hadoopip:10000/database","username", "password");

如果您使用的是hortonworks,他们已经捆绑了所有的JAR。您可以使用以下两个JAR进行连接:-

此外,您只能连接配置单元服务器2,因此您的连接字符串应该与下面的字符串类似,请使用配置单元2而不是配置单元

 Connection con = DriverManager.getConnection("jdbc:hive2://hadoopip:10000/database","username", "password");

我建议Maven过渡地管理您的依赖关系。除此之外,我认为HiveJDBC就是你的全部need@NaveenRamawat不,这是另一个错误可能是重复的或@cricket\u 007这个怎么样^^文档确实解释了您需要的所有罐子。我建议Maven过渡地管理您的依赖关系。除此之外,我认为HiveJDBC就是你的全部need@NaveenRamawat不,这是另一个错误可能是重复的或@cricket\u 007这个怎么样^^文档确实解释了您需要的所有罐子。