Johansen, thank God, did not know quite all, even though he saw the city and the Thing, but I shall never sleep calmly again when I think of the horrors that lurk ceaselessly behind life in time and in space, and of those unhallowed blasphemies from elder stars which dream beneath the sea, known and favoured by a nightmare cult ready and eager to loose them upon the world whenever another earthquake shall heave their monstrous stone city again to the sun and air.
HP Lovecraft The Call of Cthulhu, 1926
Kerberos support is built into the Java JRE. It comes in two parts
- The public APIs with some guarantee of stability at the class/method level, along with assertions of functionality behind those classes and methods.
- The internal implementation classes which are needed to do anything sophisticated.
The Hadoop UGI code uses part (2), the internal com.sun
classes, as the public APIs
are too simplistic for the authentication system.
This comes at a price
- Different JRE vendors (e.g IBMs) use different implementation classes, so will not work.
- Different Java versions can (and do) change those implementation classes.
Using internal classes is one of those "don't do this your code will be unreliable" rules; it wasn't something done lightly. In its defence, (a) it was needed and (b) it turns out that the public APIs are brittle across versions and JDKs too, so we haven't lost as much as you'd think.
- Hadoop is built and tested against the Oracle JDKs
- Open JDK has the same classes and methods, so will behave consistently; it's tested against too.
- It's left to the vendors of other JVMs to test their code; the patches are taken on trust.
- The Kerberos internal access usually needs fixing across Java versions. This means secure Hadoop clusters absolutely require the Java versions listed on the download requirements.
- Releases within a Java version may break the internals and/or the public API's behaviour.
- If you want to see the details of Hadoop's binding, look in
org.apache.hadoop.security.authentication.util.KerberosUtil
in thehadoop-auth
module.
To put it differently: