Java JDBC连接Kerberos认证的HIVE 和 Impala

打印 上一主题 下一主题

主题 924|帖子 924|积分 2772

``
1. 版本

HIVE 2.1.1-cdh6.3.2版本需对应版本的 Hive JDBC 和 Impala JDBC,如下:
   注意:单独使用HIVE JDBC ,使用版本 3.1.0,使用 Impala JDBC 需要搭配 HIVE JDBC 1.1.0使用,不然会报错;搭配HIVE JDBC 3.1.0 报:java.lang.NoClassDefFoundErrorrg/apache/hive/service/cli/thrift/TCLIService$Client
  1.        <dependency>
  2.          <groupId>org.apache.hive</groupId>
  3.          <artifactId>hive-exec</artifactId>
  4.          <version>3.1.0</version>
  5.        </dependency>
  6.        <dependency>
  7.          <groupId>org.apache.hadoop</groupId>
  8.          <artifactId>hadoop-common</artifactId>
  9.          <version>3.1.0</version>
  10.        </dependency>
  11.        <dependency>
  12. <!--        <dependency>-->
  13. <!--            <groupId>org.apache.hive</groupId>-->
  14. <!--            <artifactId>hive-jdbc</artifactId>-->
  15. <!--            <version>3.1.0</version>-->
  16. <!--        </dependency>-->
  17.        <dependency>
  18.          <groupId>org.apache.hadoop</groupId>
  19.          <artifactId>hadoop-auth</artifactId>
  20.          <version>3.1.0</version>
  21.        </dependency>
  22.        <dependency>
  23.          <groupId>com.cloudera.impala</groupId>
  24.          <artifactId>impala-jdbc41</artifactId>
  25.          <version>2.5.28</version>
  26.        </dependency>
  27.        <dependency>
  28.            <groupId>org.apache.hive</groupId>
  29.            <artifactId>hive-jdbc</artifactId>
  30.            <version>1.1.0</version>
  31.        </dependency>
复制代码
1.1 手动安装 maven

假如 Maven 库没有相应JDBC,手动安装 maven,如下:
  1. mvn install:install-file -D file=C:\Users\mx\Desktop\impala-jdbc41-0.0.1.jar -D groupId=com.cloudera.impala -D artifactId=impala-jdbc42 -D version=2.6.33 -D packaging=jar
复制代码
2. 映射地址

因kerberos SPN配置必须使用主机名链接,Linux 和 Windows需要配置hosts,格式:IP地址 主机名,配置完成之后 telnet 检测
   说明:假如是docker容器链接 Hive 或 Impala ,还需要在docker容器中配置 hosts,保证主机和容器 telent 都是通的
telnet hostname port
  

2.1 端口

开通 HIVE 和 Impala 相应的端口,当地调试按需将 IP 和 端口加入白名单


  • HIVE TCP端口:jdbc:hive2://hostname:10000
  • Impala TCP端口:jdbc:impala://hostname:21050
  • Hdfs TCP端口:hdfs://hostname:8020
  • Kerberos UDP端口:88
2.2 调试

使用 telnet hostname port ,调试以上 hostname 和 端口,保障网络连通
3 HIVE JDBC 连接 Kerberos 认证的 HIVE 集群

  1. package com.test;
  2. import java.sql.Connection;
  3. import java.sql.DriverManager;
  4. import java.sql.ResultSet;
  5. import java.sql.Statement;
  6. import org.apache.hadoop.conf.Configuration;
  7. import org.apache.hadoop.security.UserGroupInformation;
  8. public class HiveKerberosConnectionExample {
  9.     private static String krb5 = "src/main/resources/krb5.conf";
  10.     private static String keytab = "src/main/resources/hive.keytab";
  11.     private static String principal = "hive@EXAMPLE.COM";
  12.     private static String hiveUrl = "jdbc:hive2://host:10000/test;principal=hive/_HOST@EXAMPLE.COM";
  13.     public static void main(String[] args) throws Exception {
  14.         // 设置Kerberos配置文件路径
  15.         System.setProperty("java.security.krb5.conf", krb5);
  16.         System.setProperty("sun.security.krb5.debug", "true"); // 可选,用于调试 Kerberos 认证过程
  17.         // 初始化Hadoop配置
  18.         Configuration conf = new Configuration();
  19.         conf.set("hadoop.security.authentication", "kerberos");
  20.         // 使用Keytab进行Kerberos身份验证
  21.         UserGroupInformation.setConfiguration(conf);
  22.         UserGroupInformation.loginUserFromKeytab(principal, keytab);
  23.         
  24.         // 建立Hive连接
  25.         Class.forName("org.apache.hive.jdbc.HiveDriver");
  26.         Connection connection = DriverManager.getConnection(hiveUrl, "", "");
  27.         // 执行查询
  28.         Statement stmt = connection.createStatement();
  29.         ResultSet res = stmt.executeQuery("select * from test.tblname");
  30.         // 处理结果
  31.         while (res.next()) {
  32.             //a,b,c,ds 为 tblname表字段
  33.             String data = res.getString("a") + "," + res.getString("b") + "," + res.getString("c") + "," + res.getString("ds");
  34.             System.out.println("************** 输出 tblname***************************");
  35.             System.out.println(data);
  36.         }
  37.         // 关闭资源
  38.         res.close();
  39.         stmt.close();
  40.         connection.close();
  41.     }
  42. }
复制代码
4 HIVE JDBC 连接 Kerberos 认证的 Impala 集群

  1. package com.test;
  2. import org.apache.hadoop.conf.Configuration;
  3. import org.apache.hadoop.security.UserGroupInformation;
  4. import java.security.PrivilegedAction;
  5. import java.sql.*;
  6. public class ImpalaKerberosConnectionExample {
  7.     private static String krb5 = "src/main/resources/krb5.conf";
  8.     private static String keytab = "src/main/resources/impala.keytab";
  9.     private static String principal = "impala@EXAMPLE.COM";
  10.     private static String impalaUrl = "jdbc:hive2://host:21050/test;principal=impala/_HOST@EXAMPLE.COM";
  11.     public static void main(String[] args) throws Exception {
  12.         // 设置Kerberos配置文件路径
  13.         System.setProperty("java.security.krb5.conf", krb5);
  14.         System.setProperty("sun.security.krb5.debug", "true"); // 可选,用于调试 Kerberos 认证过程
  15.         // 初始化Hadoop配置
  16.         Configuration conf = new Configuration();
  17.         conf.set("hadoop.security.authentication", "kerberos");
  18.         // 使用Keytab进行Kerberos身份验证
  19.         UserGroupInformation.setConfiguration(conf);
  20.         UserGroupInformation.loginUserFromKeytab(principal, keytab);
  21.         UserGroupInformation loginUser = UserGroupInformation.getLoginUser();
  22.         //使用HIVE jdbc 建立Impala连接
  23.         Class.forName("org.apache.hive.jdbc.HiveDriver");
  24.         // Impala Jdbc 和 HIVE Jdbc 查询
  25. //        loginUser.doAs((PrivilegedAction<Void>) () -> {
  26. //            try {
  27. //                try (Connection connection = DriverManager.getConnection(impalaUrl,"","")) {
  28. //                    try (Statement statement = connection.createStatement()) {
  29. //                        ResultSet resultSet = statement.executeQuery("SELECT * FROM test.tblname LIMIT 10");
  30. //                        while (resultSet.next()) {
  31. //                            String data = resultSet.getString("a") + "," + resultSet.getString("b") + "," + resultSet.getString("c") + "," + resultSet.getString("ds");
  32. //                            System.out.println("************** 输出 tblname***************************");
  33. //                            System.out.println(data);
  34. //                        }
  35. //                        resultSet.close();
  36. //                    }
  37. //                }
  38. //            } catch (SQLException e) {
  39. //                e.printStackTrace();
  40. //            }
  41. //            return null;
  42. //        });
  43.         // HIVE JDBC 查询,Impala Jdbc 查询报 kerberos 认证失败 1312 码
  44.         Connection connection = DriverManager.getConnection(impalaUrl, "", "");
  45.         Statement stmt = connection.createStatement();
  46.         ResultSet res = stmt.executeQuery("SELECT * FROM test.tlbname LIMIT 10");
  47.         // 处理结果
  48.         while (res.next()) {
  49.             String data = res.getString("a") + "," + res.getString("b") + "," + res.getString("c") + "," + res.getString("ds");
  50.             System.out.println("************** Impala 输出 tblname ***************************");
  51.             System.out.println(data);
  52.         }
  53.         // 关闭资源
  54.         res.close();
  55.         stmt.close();
  56.         connection.close();
  57.     }
  58. }
复制代码
5 Impala JDBC 连接 Kerberos 认证的 Impala 集群

  1. package com.test;
  2. import org.apache.hadoop.conf.Configuration;
  3. import org.apache.hadoop.security.UserGroupInformation;
  4. import java.security.PrivilegedAction;
  5. import java.sql.*;
  6. public class ImpalaKerberosConnectionExample {
  7.     private static String krb5 = "src/main/resources/krb5.conf";
  8.     private static String keytab = "src/main/resources/impala.keytab";
  9.     private static String principal = "impala@EXAMPLE.COM";
  10.     private static String impalaUrl = "jdbc:impala://host:21050/test;AuthMech=1;KrbRealm=EXAMPLE.COM;KrbHostFQDN=host;KrbServiceName=impala";
  11.     public static void main(String[] args) throws Exception {
  12.         // 设置Kerberos配置文件路径
  13.         System.setProperty("java.security.krb5.conf", krb5);
  14.         System.setProperty("sun.security.krb5.debug", "true"); // 可选,用于调试 Kerberos 认证过程
  15.         // 初始化Hadoop配置
  16.         Configuration conf = new Configuration();
  17.         conf.set("hadoop.security.authentication", "kerberos");
  18.         // 使用Keytab进行Kerberos身份验证
  19.         UserGroupInformation.setConfiguration(conf);
  20.         UserGroupInformation.loginUserFromKeytab(principal, keytab);
  21.         UserGroupInformation loginUser = UserGroupInformation.getLoginUser();
  22.         // 使用 Impala jdbc 建立Impala连接
  23.         Class.forName("com.cloudera.impala.jdbc41.Driver");// 搭配HIVE JDBC 3.1.0报:java.lang.NoClassDefFoundError: org/apache/hive/service/cli/thrift/TCLIService$Client
  24.         //使用HIVE jdbc 建立Impala连接
  25. //        Class.forName("org.apache.hive.jdbc.HiveDriver");
  26.         // Impala查询
  27.         loginUser.doAs((PrivilegedAction<Void>) () -> {
  28.             try {
  29.                 try (Connection connection = DriverManager.getConnection(impalaUrl,"","")) {
  30.                     try (Statement statement = connection.createStatement()) {
  31.                         ResultSet resultSet = statement.executeQuery("SELECT * FROM test.tblname LIMIT 10");
  32.                         while (resultSet.next()) {
  33.                             String data = resultSet.getString("a") + "," + resultSet.getString("b") + "," + resultSet.getString("c") + "," + resultSet.getString("ds");
  34.                             System.out.println("************** Impala 输出 tlbname ***************************");
  35.                             System.out.println(data);
  36.                         }
  37.                         resultSet.close();
  38.                     }
  39.                 }
  40.             } catch (SQLException e) {
  41.                 e.printStackTrace();
  42.             }
  43.             return null;
  44.         });
  45.     }
  46. }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

圆咕噜咕噜

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表