spark HBaseDelegationTokenProvider 源码
spark HBaseDelegationTokenProvider 代码
文件路径:/core/src/main/scala/org/apache/spark/deploy/security/HBaseDelegationTokenProvider.scala
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.spark.deploy.security
import java.io.Closeable
import scala.reflect.runtime.universe
import scala.util.control.NonFatal
import org.apache.hadoop.conf.Configuration
import org.apache.hadoop.security.Credentials
import org.apache.hadoop.security.token.{Token, TokenIdentifier}
import org.apache.spark.SparkConf
import org.apache.spark.internal.Logging
import org.apache.spark.security.HadoopDelegationTokenProvider
import org.apache.spark.util.Utils
private[security] class HBaseDelegationTokenProvider
extends HadoopDelegationTokenProvider with Logging {
override def serviceName: String = "hbase"
override def obtainDelegationTokens(
hadoopConf: Configuration,
sparkConf: SparkConf,
creds: Credentials): Option[Long] = {
try {
val mirror = universe.runtimeMirror(Utils.getContextOrSparkClassLoader)
val obtainToken = mirror.classLoader.
loadClass("org.apache.hadoop.hbase.security.token.TokenUtil")
.getMethod("obtainToken", classOf[Configuration])
logDebug("Attempting to fetch HBase security token.")
val token = obtainToken.invoke(null, hbaseConf(hadoopConf))
.asInstanceOf[Token[_ <: TokenIdentifier]]
logInfo(s"Get token from HBase: ${token.toString}")
creds.addToken(token.getService, token)
} catch {
case NonFatal(e) =>
logWarning(Utils.createFailedToGetTokenMessage(serviceName, e) +
s" Retrying to fetch HBase security token with $serviceName connection parameter.")
// Seems to be spark is trying to get the token from HBase 2.x.x version or above where the
// obtainToken(Configuration conf) API has been removed. Lets try obtaining the token from
// another compatible API of HBase service.
obtainDelegationTokensWithHBaseConn(hadoopConf, creds)
}
None
}
/**
* Token<AuthenticationTokenIdentifier> obtainToken(Configuration conf) is a deprecated
* method and in Hbase 2.0.0 the method is already removed.
* The HBase client API used in below method is introduced from HBase 0.98.9 version,
* to invoke this api first connection object has to be retrieved from ConnectionFactory and the
* same connection can be passed to
* Token<AuthenticationTokenIdentifier> obtainToken(Connection conn) API
*
* @param hadoopConf Configuration of current Hadoop Compatible system.
* @param creds Credentials to add tokens and security keys to.
*/
private def obtainDelegationTokensWithHBaseConn(
hadoopConf: Configuration,
creds: Credentials): Unit = {
var hbaseConnection : Closeable = null
try {
val mirror = universe.runtimeMirror(Utils.getContextOrSparkClassLoader)
val connectionFactoryClass = mirror.classLoader
.loadClass("org.apache.hadoop.hbase.client.ConnectionFactory")
.getMethod("createConnection", classOf[Configuration])
hbaseConnection = connectionFactoryClass.invoke(null, hbaseConf(hadoopConf))
.asInstanceOf[Closeable]
val connectionParamTypeClassRef = mirror.classLoader
.loadClass("org.apache.hadoop.hbase.client.Connection")
val obtainTokenMethod = mirror.classLoader
.loadClass("org.apache.hadoop.hbase.security.token.TokenUtil")
.getMethod("obtainToken", connectionParamTypeClassRef)
logDebug("Attempting to fetch HBase security token.")
val token = obtainTokenMethod.invoke(null, hbaseConnection)
.asInstanceOf[Token[_ <: TokenIdentifier]]
logInfo(s"Get token from HBase: ${token.toString}")
creds.addToken(token.getService, token)
} catch {
case NonFatal(e) =>
logWarning(Utils.createFailedToGetTokenMessage(serviceName, e))
} finally {
if (null != hbaseConnection) {
hbaseConnection.close()
}
}
}
override def delegationTokensRequired(
sparkConf: SparkConf,
hadoopConf: Configuration): Boolean = {
hbaseConf(hadoopConf).get("hbase.security.authentication") == "kerberos"
}
private def hbaseConf(conf: Configuration): Configuration = {
try {
val mirror = universe.runtimeMirror(Utils.getContextOrSparkClassLoader)
val confCreate = mirror.classLoader.
loadClass("org.apache.hadoop.hbase.HBaseConfiguration").
getMethod("create", classOf[Configuration])
confCreate.invoke(null, conf).asInstanceOf[Configuration]
} catch {
case NonFatal(e) =>
// Keep at debug level since this is executed even when HBase tokens are not needed.
// Avoids a noisy warning for users who don't care about HBase.
logDebug("Unable to load HBaseConfiguration.", e)
conf
}
}
}
相关信息
相关文章
0
赞
- 所属分类: 前端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦