-
- Downloads
[SPARK-20434][YARN][CORE] Move Hadoop delegation token code from yarn to core
## What changes were proposed in this pull request? Move Hadoop delegation token code from `spark-yarn` to `spark-core`, so that other schedulers (such as Mesos), may use it. In order to avoid exposing Hadoop interfaces in spark-core, the new Hadoop delegation token classes are kept private. In order to provider backward compatiblity, and to allow YARN users to continue to load their own delegation token providers via Java service loading, the old YARN interfaces, as well as the client code that uses them, have been retained. Summary: - Move registered `yarn.security.ServiceCredentialProvider` classes from `spark-yarn` to `spark-core`. Moved them into a new, private hierarchy under `HadoopDelegationTokenProvider`. Client code in `HadoopDelegationTokenManager` now loads credentials from a whitelist of three providers (`HadoopFSDelegationTokenProvider`, `HiveDelegationTokenProvider`, `HBaseDelegationTokenProvider`), instead of service loading, which means that users are not able to implement their own delegation token providers, as they are in the `spark-yarn` module. - The `yarn.security.ServiceCredentialProvider` interface has been kept for backwards compatibility, and to continue to allow YARN users to implement their own delegation token provider implementations. Client code in YARN now fetches tokens via the new `YARNHadoopDelegationTokenManager` class, which fetches tokens from the core providers through `HadoopDelegationTokenManager`, as well as service loads them from `yarn.security.ServiceCredentialProvider`. Old Hierarchy: ``` yarn.security.ServiceCredentialProvider (service loaded) HadoopFSCredentialProvider HiveCredentialProvider HBaseCredentialProvider yarn.security.ConfigurableCredentialManager ``` New Hierarchy: ``` HadoopDelegationTokenManager HadoopDelegationTokenProvider (not service loaded) HadoopFSDelegationTokenProvider HiveDelegationTokenProvider HBaseDelegationTokenProvider yarn.security.ServiceCredentialProvider (service loaded) yarn.security.YARNHadoopDelegationTokenManager ``` ## How was this patch tested? unit tests Author: Michael Gummelt <mgummelt@mesosphere.io> Author: Dr. Stefan Schimanski <sttts@mesosphere.io> Closes #17723 from mgummelt/SPARK-20434-refactor-kerberos.
Showing
- core/pom.xml 28 additions, 0 deletionscore/pom.xml
- core/src/main/scala/org/apache/spark/deploy/security/HBaseDelegationTokenProvider.scala 5 additions, 6 deletions.../spark/deploy/security/HBaseDelegationTokenProvider.scala
- core/src/main/scala/org/apache/spark/deploy/security/HadoopDelegationTokenManager.scala 119 additions, 0 deletions.../spark/deploy/security/HadoopDelegationTokenManager.scala
- core/src/main/scala/org/apache/spark/deploy/security/HadoopDelegationTokenProvider.scala 50 additions, 0 deletions...spark/deploy/security/HadoopDelegationTokenProvider.scala
- core/src/main/scala/org/apache/spark/deploy/security/HadoopFSDelegationTokenProvider.scala 126 additions, 0 deletions...ark/deploy/security/HadoopFSDelegationTokenProvider.scala
- core/src/main/scala/org/apache/spark/deploy/security/HiveDelegationTokenProvider.scala 35 additions, 43 deletions...e/spark/deploy/security/HiveDelegationTokenProvider.scala
- core/src/test/scala/org/apache/spark/deploy/security/HadoopDelegationTokenManagerSuite.scala 116 additions, 0 deletions...k/deploy/security/HadoopDelegationTokenManagerSuite.scala
- dev/.rat-excludes 1 addition, 4 deletionsdev/.rat-excludes
- docs/running-on-yarn.md 6 additions, 6 deletionsdocs/running-on-yarn.md
- resource-managers/yarn/pom.xml 6 additions, 8 deletionsresource-managers/yarn/pom.xml
- resource-managers/yarn/src/main/resources/META-INF/services/org.apache.spark.deploy.yarn.security.ServiceCredentialProvider 0 additions, 3 deletions...ache.spark.deploy.yarn.security.ServiceCredentialProvider
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/ApplicationMaster.scala 7 additions, 3 deletions...cala/org/apache/spark/deploy/yarn/ApplicationMaster.scala
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/Client.scala 6 additions, 3 deletions.../src/main/scala/org/apache/spark/deploy/yarn/Client.scala
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/YarnSparkHadoopUtil.scala 27 additions, 4 deletions...la/org/apache/spark/deploy/yarn/YarnSparkHadoopUtil.scala
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/security/AMCredentialRenewer.scala 4 additions, 2 deletions...ache/spark/deploy/yarn/security/AMCredentialRenewer.scala
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/security/CredentialUpdater.scala 1 addition, 1 deletion...apache/spark/deploy/yarn/security/CredentialUpdater.scala
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/security/ServiceCredentialProvider.scala 2 additions, 1 deletion...park/deploy/yarn/security/ServiceCredentialProvider.scala
- resource-managers/yarn/src/main/scala/org/apache/spark/deploy/yarn/security/YARNHadoopDelegationTokenManager.scala 83 additions, 0 deletions...ploy/yarn/security/YARNHadoopDelegationTokenManager.scala
- resource-managers/yarn/src/test/resources/META-INF/services/org.apache.spark.deploy.yarn.security.ServiceCredentialProvider 1 addition, 1 deletion...ache.spark.deploy.yarn.security.ServiceCredentialProvider
- resource-managers/yarn/src/test/scala/org/apache/spark/deploy/yarn/security/YARNHadoopDelegationTokenManagerSuite.scala 66 additions, 0 deletions...yarn/security/YARNHadoopDelegationTokenManagerSuite.scala
Loading
Please register or sign in to comment