DolphinScheduler启用Kerberos(亲测)
创始人
2024-05-30 09:34:17
0

环境背景

使用DolphinScheduler3.0.0+CDH6.3.2(适配之前已存在任务环境)

已知问题

  1. DolphinScheduler3.1.4默认是zookeeper3.8,需要手动编译zk3.4+

  1. DolphinScheduler的hive相关依赖和CDH的版本不一致,需要在编译时修改pom文件

  1. 开启Kerberos时使用DolphinScheduler添加Hive数据源日志报错Peer indicated failure: Unsupported mechanism type PLAIN,在github的issue上有人说是bug,所以我手动编译3.1.4版本,问题依然存在,最终确定是依赖问题,下面附解决方法

添加hive数据源jdbc连接参数{"principal":"hive/_HOST@EXAMPLE.COM"}

开始配置

  1. 按照官网说明修改master,worker,api模块下面的conf/common.properties相关的Kerberos配置

  1. 使用kadmin.local生成keytab文件及相应的princal,不让之前配置密码失效加-norandkey

kadmin.local -q "xst -k /opt/hdfs.keytab hdfs@EXAMPLE.COM"
  1. 配置正确重启小海豚,spark任务不需要任何修改是可以正常执行的,添加hive数据异常,解决方法如下:

思路参考

先添加jdbc连接参数{"principal":"hive/_HOST@EXAMPLE.COM"}连接成功,后执行以下导致误以为是jar包导致的

(1)重新编译小海豚,修改pom文件,添加hive-shim依赖注意版本

(2)使用$CDH_HOME/jars目录下的jar替换小海豚的master,worker,api的libs目录下依赖

cdh_jars="/opt/cloudera/parcels/CDH-6.3.2-1.cdh6.3.2.p0.1605554/jars"
dol314="/opt/software/bigdata/dolphinscheduler314"
cd $dol314
mkdir ext
cp $cdh_jars/hive-common-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-jdbc-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-metastore-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-serde-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-service-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-service-rpc-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-shims-0.23-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-shims-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-shims-common-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-shims-scheduler-2.1.1-cdh6.3.2.jar $dol314/ext
cp $cdh_jars/hive-storage-api-2.1.1-cdh6.3.2.jar $dol314/ext
rm -rf $dol314/mater-server/libs/hive-*
rm -rf $dol314/worker-server/libs/hive-*
rm -rf $dol314/api-server/libs/hive-*
cp -rf $dol314/ext/* $dol314/mater-server/libs
cp -rf $dol314/ext/* $dol314/worker-server/libs
cp -rf $dol314/ext/* $dol314/api-server/libs

重启小海豚,添加hive数据源成功

可能报错

  1. java.sql.SQLException: Could not open client transport with JDBC Uri: GSS initiate failed

检查配置的kerberos相关信息是否正确

  1. java.lang.NoClassDefFoundError: org/apache/hadoop/hive/thrift/TFilterTransport

jar包依赖问题或者jdbc连接参数中存在{"principal":"hive/_HOST@EXAMPLE.COM"}

注意事项

  1. hive的principle可以使用配置文件里面的,也可以使用CM创建的hive/master@EXAMPLE.COM,用户名默认hive就行

  1. kerberos命名规则,用户/主机@Realm,使用keytab,原来的密码失效(创建keytab可添加密码不失效参数-norandkey),一个用户可以访问所有服务

  1. window客户端使用要保证krb5.conf的kdc和admin_server和服务端一致

相关内容

热门资讯

创世纪跌2.02%,成交额74... 7月4日,创世纪盘中下跌2.02%,截至09:43,报8.25元/股,成交7446.18万元,换手率...
太阳能涨2.04%,成交额72... 7月4日,太阳能盘中上涨2.04%,截至09:41,报4.51元/股,成交7286.56万元,换手率...
使用word制作一个创业计划书... (4)书店描述1.书店名称:墨香斋2、书店的宗旨:为客户和社会提供最周到的服务和最便宜的产品,同时高...
生物医药ETF基金(15950... 7月4日,生物医药ETF基金(159508)开盘涨0.00%,报0.790元。生物医药ETF基金(1...
世界环保创业基金会官网会员登录... 这个平台没有充值口,没有提现口,没有现金池。矿工自己交易,平台只负责监管。您的货币可以随时兑现!《G...
铂力特股价跌5.08%,华泰柏... 7月4日,铂力特跌5.08%,截至发稿,报62.74元/股,成交3.14亿元,换手率1.82%,总市...
百利天恒涨2.04%,成交额2... 7月4日,百利天恒盘中上涨2.04%,截至09:36,报304.07元/股,成交2710.54万元,...
江盐集团7月3日获融资买入24... 7月3日,江盐集团跌0.36%,成交额3337.64万元。两融数据显示,当日江盐集团获融资买入额24...
上海创意园区 排名(上海的创业... 废弃的厂房,空置的仓库.它们已经成为超级风格的创意公园在这些地方,时间似乎停止了流逝当工业历史元素与...
白风是好人还是坏人 白风是好人还是坏人说不上好坏,在当时的背景下,他只是遵循本心而活,他看到了太多的黑暗,内心脆弱,可以...