使用confluent将Kafka中的数据入库hive失败的解决方案
应用场景:
用户想在 HD平台使用confluent开源组件将Kafka中的数据直接导入到hive中,测试环境中已经实现,但生产环境中由于平台开启了Kerberos安全认证服务,所以一直报认证失败的日志.
data:image/s3,"s3://crabby-images/a747d/a747dc1228429a064ff9d45e0fced788e6e1efce" alt=""
confluent:
confluent将数据导入hive库: 先将数据导入到hdfs上指定的目录下,然后通过外表的形式入库hive.
confluent通过metastore服务(thirft://url:9083))获取hive的元数据.
官网配置文档:
数据导入hdfs的配置:
`name=hdfs-sink`
`connector.class=io.confluent.connect.hdfs.HdfsSinkConnector`
`tasks.max=1`
`topics=test_hdfs`
`hdfs.url=hdfs://localhost:9000`
`flush.size=3`
数据直接入户hive需要增加的配置:
`hive.integration=true`
`hive.metastore.uris=thrift://localhost:9083 `
`schema.compatibility=BACKWARD`
如果平台有Kerberos安全认证需要增加的配置:
`hdfs.authentication.kerberos=true`
`connect.hdfs.principal=connect-hdfs/_HOST@YOUR-REALM.COM`
`connect.hdfs.keytab=path to the connector `
`keytab
hdfs.namenode.principal=namenode principal`
问题排查:
通过查看confluent和hive的部分代码发现confluent导入数据到hive共需要两次认证:
第一次登陆是在io.confluent.connect.hdfs.DataWriter中使用confluent配置文件中connect.hdfs.principal提供的principal登陆
data:image/s3,"s3://crabby-images/493d1/493d18654544f6d08b1567fd6e7503d5be645bd2" alt=""
第二次登陆是在org.apache.hadoop.hive.metastore.HiveMetaStoreClient中通过hive-site.xml文件中的配置信息登陆
如果sasl参数设置为true则先认证,然后获取client,如果sasl参数为false,则先获取client,然后进行非安全模式下的认证.两种模式通过不同的方式获取道德用户信息是不同的,安全模式下用户为Kerberos用户(如principal=connect-hdfs/_HOST@YOUR-REALM.COM,则用户名为connect-hdfs),非安全模式下的用户为Linux上的用户(whoami).
data:image/s3,"s3://crabby-images/dcc72/dcc725f00036299a9e9db6d7a0ac58c3a55d210e" alt=""
hive-site.xml文件加载
data:image/s3,"s3://crabby-images/3c22e/3c22e77db7a45019317fd756f0fbd19faf8d9d65" alt=""
data:image/s3,"s3://crabby-images/13ea9/13ea931f680efe4f5bbdd5ae99cdf792dbde83ba" alt=""
由于confluent的配置文件中没有配置hive.conf.dir参数,因此使用了sasl的默认值false,导致认证失败.
data:image/s3,"s3://crabby-images/e7f50/e7f50d09ec87dc4f25a93fb0e47a95f843de5dfe" alt=""
网友评论